﻿*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{height:100%;font-size:14px;}
body{font-family:'Inter',sans-serif;background:#060d18;color:#e2e8f0;height:100%;-webkit-font-smoothing:antialiased;overflow:hidden;}

:root{
  --bg:#070d1a;
  --bg2:#090f1d;
  --sidebar:#070d1a;
  --surface:#0b1525;
  --card:#0c1524;
  --card2:#0e192a;
  --border:rgba(255,255,255,0.06);
  --border2:rgba(255,255,255,0.09);
  --text:#e2e8f0;
  --text2:#cbd5e1;
  --muted:#64748b;
  --muted2:#334155;
  --accent:#3b82f6;
  --accent2:#60a5fa;
  --accent-bg:rgba(59,130,246,0.15);
  --accent-border:rgba(59,130,246,0.3);
  --success:#22c55e;
  --success-bg:rgba(34,197,94,0.12);
  --warn:#f59e0b;
  --danger:#ef4444;
  --r:0.5rem;
  --r-sm:0.375rem;
  --sidebar-w:260px;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:99px;}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.2);}
*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.1) transparent;}

/* ── SPACE BACKGROUND ── */
body::before{content:'';position:fixed;inset:0;z-index:-2;background:radial-gradient(ellipse at 15% 40%,rgba(59,130,246,0.04) 0%,transparent 55%),radial-gradient(ellipse at 85% 15%,rgba(99,102,241,0.03) 0%,transparent 45%),radial-gradient(ellipse at 55% 85%,rgba(16,185,129,0.025) 0%,transparent 40%),#070d1a;}
body::after{content:'';position:fixed;inset:0;z-index:-1;background-image:radial-gradient(1px 1px at 10% 15%,rgba(255,255,255,0.18) 0%,transparent 100%),radial-gradient(1px 1px at 25% 35%,rgba(255,255,255,0.12) 0%,transparent 100%),radial-gradient(1px 1px at 40% 10%,rgba(255,255,255,0.15) 0%,transparent 100%),radial-gradient(1px 1px at 55% 60%,rgba(255,255,255,0.1) 0%,transparent 100%),radial-gradient(1px 1px at 70% 25%,rgba(255,255,255,0.14) 0%,transparent 100%),radial-gradient(1px 1px at 85% 45%,rgba(255,255,255,0.1) 0%,transparent 100%),radial-gradient(1px 1px at 15% 70%,rgba(255,255,255,0.08) 0%,transparent 100%),radial-gradient(1px 1px at 30% 80%,rgba(255,255,255,0.12) 0%,transparent 100%),radial-gradient(1px 1px at 65% 75%,rgba(255,255,255,0.1) 0%,transparent 100%),radial-gradient(1px 1px at 90% 65%,rgba(255,255,255,0.12) 0%,transparent 100%);pointer-events:none;}

/* ── LAYOUT ── */
.app{display:flex;height:100vh;overflow:hidden;}
#loginPage{display:flex;align-items:center;justify-content:center;height:100vh;width:100%;background:var(--bg);position:relative;overflow:hidden;}
#loginPage::before{content:'';position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse at 20% 40%,rgba(59,130,246,0.07) 0%,transparent 55%),radial-gradient(ellipse at 80% 20%,rgba(99,102,241,0.05) 0%,transparent 45%),radial-gradient(ellipse at 60% 80%,rgba(16,185,129,0.04) 0%,transparent 40%);}
#loginPage::after{content:'';position:absolute;inset:0;z-index:0;background-image:radial-gradient(1px 1px at 10% 15%,rgba(255,255,255,0.22) 0%,transparent 100%),radial-gradient(1px 1px at 25% 35%,rgba(255,255,255,0.14) 0%,transparent 100%),radial-gradient(1px 1px at 55% 60%,rgba(255,255,255,0.12) 0%,transparent 100%),radial-gradient(1px 1px at 70% 25%,rgba(255,255,255,0.16) 0%,transparent 100%),radial-gradient(1px 1px at 90% 65%,rgba(255,255,255,0.14) 0%,transparent 100%),radial-gradient(1px 1px at 45% 85%,rgba(255,255,255,0.1) 0%,transparent 100%);pointer-events:none;}
#loginPage .lw{position:relative;z-index:1;}
#dashPage{display:none;width:100%;}
.dash{display:flex;height:100vh;}

/* ── SIDEBAR ── */
.sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);
  background:rgba(4,8,18,0.85);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  height:100vh;flex-shrink:0;overflow-y:auto;
}
.sb-header{
  height:72px;display:flex;align-items:center;
  padding:0 16px;border-bottom:1px solid var(--border);
  flex-shrink:0;gap:12px;
}
.sb-logo{width:40px;height:40px;border-radius:0.5rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sb-name{font-size:1.1rem;font-weight:700;color:var(--text);line-height:1.2;}
.sb-sub{font-size:0.68rem;font-weight:600;color:var(--accent2);letter-spacing:0.07em;text-transform:uppercase;margin-top:2px;}
.sb-nav{padding:12px 8px;flex:1;}
.sb-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:var(--r-sm);
  font-size:0.98rem;font-weight:500;color:#b0bfd0;
  cursor:pointer;transition:all 0.12s;user-select:none;
}
.sb-item svg{width:22px;height:22px;flex-shrink:0;}
.sb-item:hover{background:rgba(255,255,255,0.05);color:#dde6f0;}
.sb-item.active{background:var(--accent-bg);color:var(--accent2);border:1px solid var(--accent-border);}
.sb-item.active svg{color:var(--accent2);}
.sb-divider{height:1px;background:var(--border);margin:8px 4px;}
.sb-section{font-size:0.68rem;font-weight:600;color:var(--muted2);text-transform:uppercase;letter-spacing:0.08em;padding:10px 12px 4px;}
.sb-item.admin-item{color:#f87171;}
.sb-item.admin-item:hover{background:rgba(239,68,68,0.08);color:#fca5a5;}
.sb-item.admin-item.open{background:rgba(239,68,68,0.1);color:#f87171;}
.sb-subitem{display:flex;align-items:center;gap:10px;padding:8px 12px 8px 32px;border-radius:var(--r-sm);font-size:0.88rem;font-weight:500;color:#64748b;cursor:pointer;transition:all 0.12s;user-select:none;}
.sb-subitem svg{width:16px;height:16px;flex-shrink:0;}
.sb-subitem:hover{background:rgba(255,255,255,0.04);color:#94a3b8;}
.sb-subitem.active{background:var(--accent-bg);color:var(--accent2);}

/* ── GOAL BANNER ── */
#goalBanner{display:none;position:relative;z-index:50;background:rgba(34,197,94,0.12);border-bottom:1px solid rgba(34,197,94,0.3);}
#goalBanner.show{display:block;}
.goal-banner-inner{display:flex;align-items:center;gap:16px;padding:11px 24px;}
.goal-banner-icon{width:26px;height:26px;border-radius:50%;background:rgba(34,197,94,0.18);border:1px solid rgba(34,197,94,0.4);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.goal-banner-text{flex:1;min-width:0;display:flex;align-items:center;gap:12px;overflow:hidden;}
.goal-banner-title{font-size:0.9rem;font-weight:700;color:#22c55e;white-space:nowrap;flex-shrink:0;}
.goal-banner-sep{color:rgba(34,197,94,0.4);flex-shrink:0;}
.goal-banner-items{font-size:0.9rem;font-weight:500;color:#86efac;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.goal-banner-close{background:none;border:none;color:rgba(34,197,94,0.45);cursor:pointer;padding:2px 6px;border-radius:4px;font-size:1rem;line-height:1;flex-shrink:0;}
.goal-banner-close:hover{color:#22c55e;}

/* ── MAIN ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}

/* ── TOPBAR ── */
.topbar{
  height:64px;flex-shrink:0;
  background:rgba(6,13,24,0.6);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;
  box-shadow:0 1px 3px rgba(0,0,0,0.3);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.user-btn{
  display:flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:var(--r-sm);
  background:var(--card);border:1px solid var(--border2);
  color:var(--text2);cursor:pointer;font-size:0.85rem;font-weight:500;
  font-family:'Inter',sans-serif;transition:all 0.12s;
}
.user-btn:hover{background:var(--card2);}
.user-av{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,#3b82f6,#1d4ed8);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:0.75rem;font-weight:700;flex-shrink:0;
}

/* ── CONTENT ── */
.content{flex:1;overflow-y:auto;padding:24px 28px;}
.content-inner{max-width:1280px;margin:0 auto;}
.page-header{margin-bottom:24px;}
.page-title{font-size:1.6rem;font-weight:700;color:var(--text);}
.page-sub{font-size:0.85rem;color:var(--muted);margin-top:3px;}

/* ── STATS ── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;}
.sc{
  background:var(--card);border:1px solid var(--border);
  border-radius:0.875rem;padding:20px 22px;
  display:flex;flex-direction:row;align-items:center;
  gap:16px;min-height:88px;transition:border-color 0.15s;
}
.sc:hover{border-color:var(--border2);}
.sc-icon{width:44px;height:44px;border-radius:0.625rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sc-icon.blue{background:rgba(59,130,246,0.15);}
.sc-icon.green{background:rgba(34,197,94,0.12);}
.sc-icon.indigo{background:rgba(99,102,241,0.12);}
.sc-icon.gray{background:rgba(100,116,139,0.12);}
.sc-body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;}
.sc-label{font-size:0.7rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;}
.sc-val{font-size:1.5rem;font-weight:700;color:var(--text);line-height:1.1;}
.sc-lbl{font-size:0.72rem;color:var(--muted);text-transform:none;}

/* ── TABS ── */
.tabs-row{margin-bottom:16px;}
.tabs-bg{
  display:inline-flex;align-items:center;gap:2px;
  background:#0a1628;border-radius:var(--r-sm);
  padding:3px;height:38px;
}
.tab{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 14px;border-radius:5px;
  font-size:0.82rem;font-weight:500;color:var(--muted);
  cursor:pointer;background:transparent;border:1px solid transparent;
  font-family:'Inter',sans-serif;transition:all 0.12s;height:30px;
}
.tab svg{width:15px;height:15px;}
.tab:hover{color:var(--text2);}
.tab.active{background:#0f1f3d;color:var(--text);border-color:rgba(255,255,255,0.1);}

/* ── FILTER BAR ── */
.filter-row{
  display:grid;grid-template-columns:1fr 1fr 1fr 1fr;
  gap:12px;margin-bottom:16px;
}
.fg{display:flex;flex-direction:column;gap:5px;}
.fg label{font-size:0.75rem;color:var(--muted);font-weight:500;}
.fg select,.fg input{
  height:38px;padding:0 10px;
  background:var(--card);border:1px solid var(--border2);
  border-radius:var(--r-sm);color:var(--text2);
  font-family:'Inter',sans-serif;font-size:0.82rem;outline:none;
  transition:border-color 0.15s;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;
  padding-right:30px;
}
.fg input{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");
  padding-left:34px;padding-right:10px;
  background-position:left 10px center;
}
.fg select option{background:#0f1a2e;}
.fg select:focus,.fg input:focus{border-color:var(--accent);}
.filter-row.mine{grid-template-columns:1fr auto;}
.filter-row.org{grid-template-columns:1fr 1fr 1fr;}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  height:38px;padding:0 16px;border:none;border-radius:var(--r-sm);
  font-family:'Inter',sans-serif;font-size:0.82rem;font-weight:500;
  cursor:pointer;transition:all 0.12s;white-space:nowrap;
}
.btn svg{width:14px;height:14px;flex-shrink:0;}
.btn-primary{background:var(--accent);color:#fff;}
.btn-primary:hover{background:#2563eb;}
.btn-outline{background:transparent;border:1px solid var(--border2);color:var(--muted);}
.btn-outline:hover{border-color:var(--text2);color:var(--text2);}
.btn-ghost{background:transparent;border:1px solid transparent;color:var(--muted);}
.btn-ghost:hover{color:var(--danger);}
.btn-warn-ghost{background:transparent;border:1px solid transparent;color:var(--muted);}
.btn-warn-ghost:hover{color:var(--warn);}
.btn-saida{
  display:inline-flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;
  height:32px!important;padding:0 10px!important;gap:5px!important;white-space:nowrap!important;
  font-size:0.75rem!important;font-weight:600!important;
  background:rgba(245,158,11,0.1)!important;
  border:1px solid rgba(245,158,11,0.35)!important;
  color:#f59e0b!important;border-radius:6px!important;
  cursor:pointer;transition:all 0.15s!important;
}
.btn-saida:hover{background:rgba(245,158,11,0.22)!important;border-color:rgba(245,158,11,0.6)!important;color:#fbbf24!important;transform:translateY(-1px);box-shadow:0 2px 8px rgba(245,158,11,0.2);}
.btn-saida svg{width:13px!important;height:13px!important;margin-bottom:2px;}
.btn-success{background:rgba(34,197,94,0.12);border:1px solid rgba(34,197,94,0.25);color:var(--success);}
.btn-success:hover{background:rgba(34,197,94,0.2);}
.btn-sm{height:32px;padding:0 12px;font-size:0.78rem;}

/* ── ADD PANEL ── */
#addPanel{
  background:var(--card);border:1px solid var(--border);
  border-radius:0.75rem;padding:20px;margin-bottom:16px;display:none;
}
.panel-ttl{font-size:0.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:16px;}
.fg2{display:grid;grid-template-columns:2fr 1fr 1fr;gap:10px;}
.fg2 .s2{grid-column:span 2;}
.fg2 .s3{grid-column:span 3;}
.ff{display:flex;flex-direction:column;gap:5px;}
.ff label{font-size:0.72rem;font-weight:500;color:var(--muted);}
.ff input,.ff select{
  height:36px;padding:0 10px;
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--r-sm);color:var(--text);
  font-family:'Inter',sans-serif;font-size:0.82rem;outline:none;
  transition:border-color 0.15s;
}
.ff select{
  appearance:none;padding-right:28px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 8px center;
  background-color:var(--bg2);
}
.ff select option{background:#0f1a2e;}
.ff input:focus,.ff select:focus{border-color:var(--accent);}
.qhint{font-size:0.7rem;color:var(--muted);font-weight:500;margin-left:4px;}
.qhint.warn{color:#fff;background:rgba(239,68,68,0.35);border-radius:4px;padding:1px 7px;font-weight:600;}
.form-acts{display:flex;gap:8px;margin-top:14px;}

/* ── TABLE ── */
.tbl-wrap{
  background:var(--card);border:1px solid var(--border);
  border-radius:0.75rem;overflow:hidden;
}
table{width:100%;border-collapse:collapse;table-layout:fixed;}
thead th{
  padding:12px 16px;text-align:left;
  font-size:0.75rem;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:0.04em;
  border-bottom:1px solid var(--border);white-space:nowrap;
  background:var(--card);overflow:hidden;
}
th.r,td.r{text-align:right;}
tbody tr{border-bottom:1px solid rgba(255,255,255,0.04);transition:background 0.1s;cursor:default;}
tbody tr:last-child{border-bottom:none;}
tbody tr:hover{background:rgba(59,130,246,0.04);}
tbody td{padding:14px 16px;font-size:0.9rem;vertical-align:middle;overflow:hidden;}
/* Fixed column widths */
col.c-item{width:auto;}
col.c-tipo{width:120px;}
col.c-loc{width:180px;}
col.c-qty{width:120px;}
col.c-qual{width:90px;}
col.c-det{width:80px;}
col.c-act{width:160px;}

/* ── ITEM ROW ── */
.item-icon{
  width:34px;height:34px;border-radius:var(--r-sm);
  background:rgba(100,116,139,0.15);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--muted);
}
.item-icon.comm{background:rgba(245,158,11,0.12);color:#f59e0b;}
.item-icon.ship{background:rgba(59,130,246,0.12);color:#60a5fa;}
.item-icon.roc{background:rgba(168,85,247,0.12);color:#c084fc;}
.item-icon.gem{background:rgba(20,184,166,0.12);color:#2dd4bf;}
.item-cell{display:flex;align-items:center;gap:12px;}
.item-name{font-weight:600;color:var(--text);font-size:0.92rem;}
.item-sub{font-size:0.75rem;color:var(--muted);margin-top:2px;}

/* ── BADGES ── */
.badge{
  display:inline-flex;align-items:center;
  padding:3px 10px;border-radius:9999px;
  font-size:0.72rem;font-weight:600;border:1px solid;
  white-space:nowrap;
}
.badge-comm{background:rgba(245,158,11,0.1);color:#f59e0b;border-color:rgba(245,158,11,0.25);}
.badge-ship{background:rgba(59,130,246,0.1);color:#60a5fa;border-color:rgba(59,130,246,0.25);}
.badge-roc{background:rgba(168,85,247,0.1);color:#c084fc;border-color:rgba(168,85,247,0.25);}
.badge-gem{background:rgba(20,184,166,0.1);color:#2dd4bf;border-color:rgba(20,184,166,0.25);}

/* ── QUANTITY ── */
.qty-big{font-size:1.15rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;}
.qty-scu{font-size:0.72rem;color:var(--muted);margin-left:3px;}

/* ── STATUS / AVAIL ── */
.status-cell{display:inline-flex;align-items:center;gap:5px;font-size:0.88rem;font-weight:600;color:var(--success);}
.status-dot{width:7px;height:7px;border-radius:50%;background:var(--success);flex-shrink:0;}

/* ── HOLDERS ── */
.holders-cell{display:inline-flex;align-items:center;gap:5px;font-size:0.82rem;color:var(--muted);}
.holders-cell svg{width:14px;height:14px;}

/* ── QUAL ── */


/* ── CHEVRON ── */
.chevron-cell{color:var(--muted2);cursor:pointer;transition:color 0.12s;}
.chevron-cell:hover{color:var(--text2);}

/* ── ORG SUB-ROWS ── */

.sub-table{width:100%;border-collapse:collapse;background:rgba(0,0,0,0.18);}
.sub-table td{padding:16px 16px;font-size:0.9rem;vertical-align:middle;border-bottom:1px solid rgba(255,255,255,0.06);}
.sub-table tr{height:52px;}.sub-table tr:last-child td{border-bottom:none;}
.sub-table tr:hover td{background:rgba(59,130,246,0.04);}
.sub-table td.r{text-align:right;}
.sub-member{display:contents;}
.player-pill{display:inline-flex;align-items:center;gap:5px;border-radius:4px;padding:2px 9px;font-size:0.75rem;font-weight:600;white-space:nowrap;}
.sub-qty{font-weight:700;color:var(--text);font-size:1rem;}
.sub-qual{color:var(--accent2);font-size:0.82rem;font-weight:600;}
.sub-loc{color:var(--muted);font-size:0.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sub-scu{font-size:0.72rem;color:var(--muted);margin-left:3px;}

/* ── EXPAND ── */
.org-row{cursor:pointer;}
.org-row:hover td{background:rgba(59,130,246,0.03);}
.exp-icon{width:16px;height:16px;color:var(--muted);flex-shrink:0;transition:transform 0.18s;}
.exp-icon.open{transform:rotate(90deg);}

/* ── INLINE EDIT ── */
tr.editing td{padding:6px 10px;}
tr.editing .ff input,tr.editing .ff select{height:30px;font-size:0.82rem;}

/* ── EMPTY ── */
.empty{padding:64px 20px;text-align:center;}
.empty svg{color:var(--muted2);margin-bottom:12px;}
.empty p{font-size:0.88rem;color:var(--muted);}

/* ── LOGIN ── */
.lw{width:100%;max-width:400px;padding:20px;}
.lbrand{display:flex;align-items:center;gap:14px;margin-bottom:28px;}
.lbrand-icon{width:52px;height:52px;border-radius:0.625rem;display:flex;align-items:center;justify-content:center;overflow:hidden;background:transparent;}
.lbrand-name{font-size:1.3rem;font-weight:700;color:var(--text);}
.lbrand-sub{font-size:0.78rem;color:var(--accent2);font-weight:600;letter-spacing:0.05em;text-transform:uppercase;margin-top:2px;}
.lcard{background:rgba(12,21,36,0.6);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.08);border-radius:1rem;padding:28px;box-shadow:0 8px 32px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.05);}
.lcard h2{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:5px;}
.lcard .lsub{font-size:0.85rem;color:var(--muted);margin-bottom:22px;line-height:1.5;}
.atabs{display:flex;gap:2px;margin-bottom:22px;background:rgba(255,255,255,0.04);border-radius:var(--r-sm);padding:3px;}
.atab{flex:1;text-align:center;padding:7px;border-radius:5px;font-size:0.85rem;font-weight:500;color:var(--muted);cursor:pointer;border:1px solid transparent;transition:all 0.12s;font-family:'Inter',sans-serif;}
.atab.active{background:rgba(15,25,48,0.8);color:var(--text);border-color:var(--border2);}
.lf{margin-bottom:14px;}
.lf label{display:block;font-size:0.75rem;font-weight:500;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:0.04em;}
.lf input{width:100%;height:38px;padding:0 12px;background:rgba(255,255,255,0.04);border:1px solid var(--border2);border-radius:var(--r-sm);color:var(--text);font-family:'Inter',sans-serif;font-size:0.88rem;outline:none;transition:border-color 0.15s;}
.lf input:focus{border-color:var(--accent);}
.btn-full{width:100%;justify-content:center;}

/* ── PASSWORD PAGE ── */
#pwPage{display:none;max-width:420px;}
#pwPage .pw-card{background:var(--card);border:1px solid var(--border);border-radius:0.75rem;padding:24px;}
#pwPage h3{font-size:0.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:18px;}

/* ── MODAL ── */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,0.75);display:flex;align-items:center;justify-content:center;z-index:500;padding:20px;}
.modal-box{background:var(--card);border:1px solid var(--border);border-radius:0.75rem;padding:24px;width:100%;max-width:380px;overflow:visible;}
.modal-box h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:4px;}
.modal-sub{font-size:0.85rem;color:var(--muted);margin-bottom:18px;}
.modal-name{font-size:0.95rem;font-weight:600;color:var(--accent2);margin-bottom:3px;}
.modal-stock{font-size:0.82rem;color:var(--muted);margin-bottom:14px;}
.modal-acts{display:flex;gap:8px;margin-top:16px;}

/* ── TOAST ── */
#toast{position:fixed;bottom:24px;right:24px;padding:10px 16px;border-radius:var(--r-sm);font-size:0.82rem;font-weight:500;z-index:999;transform:translateY(10px);opacity:0;transition:all 0.2s;pointer-events:none;max-width:320px;}
#toast.show{transform:translateY(0);opacity:1;}
#toast.ok{background:#052e16;border:1px solid rgba(34,197,94,0.3);color:var(--success);}
#toast.err{background:#1c0a0a;border:1px solid rgba(239,68,68,0.3);color:var(--danger);}

@media(max-width:900px){.stats-row{grid-template-columns:repeat(2,1fr);}.filter-row{grid-template-columns:1fr 1fr;}}
@media(max-width:700px){.sidebar{display:none;}.fg2{grid-template-columns:1fr 1fr;}.fg2 .s3{grid-column:span 2;}}

/* ── OBJETIVOS ── */
.obj-list{display:flex;flex-direction:column;gap:8px;width:100%;}
.obj-card{background:var(--card);border:1px solid var(--border);border-radius:0.75rem;padding:14px 20px;display:flex;flex-direction:row;align-items:center;gap:14px;transition:border-color 0.2s,transform 0.15s,box-shadow 0.2s;min-height:58px;}

.obj-card:hover{border-color:var(--border2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,0.2);}
.obj-rank{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:800;flex-shrink:0;letter-spacing:-0.02em;}
.obj-rank.r1{background:rgba(251,191,36,0.12);color:#fbbf24;border:2px solid rgba(251,191,36,0.35);}
.obj-rank.r2{background:rgba(148,163,184,0.12);color:#94a3b8;border:2px solid rgba(148,163,184,0.25);}
.obj-rank.r3{background:rgba(180,120,60,0.12);color:#b47c3c;border:2px solid rgba(180,120,60,0.25);}
.obj-rank.rn{background:rgba(100,116,139,0.08);color:var(--muted);border:1px solid var(--border);}
.obj-info{flex:1;}
.obj-name{font-size:1rem;font-weight:700;color:var(--text);}
.obj-desc{font-size:0.82rem;color:var(--muted);margin-top:3px;}
.obj-priority-1 .obj-card{border-color:rgba(251,191,36,0.3);}
.obj-drag-handle{color:var(--muted2);cursor:grab;padding:4px;}
.obj-drag-handle:active{cursor:grabbing;}
.obj-edit-row{display:flex;gap:8px;align-items:center;background:var(--card2);border:1px solid var(--border2);border-radius:0.75rem;padding:14px 16px;}

/* ── REGRAS ── */
.rules-section{margin-top:36px;}
.rules-section-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border2);}
.rules-section-icon{width:34px;height:34px;border-radius:0.5rem;background:rgba(99,102,241,0.12);border:1px solid rgba(99,102,241,0.2);display:flex;align-items:center;justify-content:center;color:#818cf8;flex-shrink:0;}
.rules-section-title{font-size:1.05rem;font-weight:700;color:var(--text);}
.rules-section-sub{font-size:0.78rem;color:var(--muted);margin-top:2px;}
.rules-list{display:flex;flex-direction:column;gap:12px;}
.rule-card{background:var(--card);border:1px solid var(--border);border-left:4px solid rgba(99,102,241,0.5);border-radius:0.75rem;padding:22px 26px;display:flex;align-items:flex-start;gap:18px;transition:border-color 0.15s,box-shadow 0.15s;}
.rule-card:hover{border-color:rgba(99,102,241,0.4);box-shadow:0 4px 16px rgba(0,0,0,0.2);}
.rule-num{width:34px;height:34px;border-radius:50%;background:rgba(99,102,241,0.12);border:1px solid rgba(99,102,241,0.25);display:flex;align-items:center;justify-content:center;font-size:0.8rem;font-weight:800;color:#818cf8;flex-shrink:0;margin-top:2px;}
.rule-body{flex:1;min-width:0;}
.rule-title{font-size:1.15rem;font-weight:700;color:var(--text);line-height:1.4;}
.rule-desc{font-size:0.95rem;color:var(--text2);margin-top:8px;line-height:1.8;white-space:pre-wrap;}
.rule-tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:9999px;font-size:0.72rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;margin-top:12px;}
.rule-tag.warn{background:rgba(245,158,11,0.1);color:#f59e0b;border:1px solid rgba(245,158,11,0.2);}
.rule-tag.info{background:rgba(59,130,246,0.1);color:#60a5fa;border:1px solid rgba(59,130,246,0.2);}
.rule-tag.danger{background:rgba(239,68,68,0.1);color:#f87171;border:1px solid rgba(239,68,68,0.2);}
.rule-tag.success{background:rgba(34,197,94,0.1);color:#22c55e;border:1px solid rgba(34,197,94,0.2);}
.rule-empty{padding:48px 0;text-align:center;color:var(--muted);font-size:0.9rem;}
/* admin edit inline */
.rule-edit-row{background:var(--card2);border:1px solid var(--accent-border);border-radius:0.75rem;padding:16px;margin-bottom:8px;display:flex;flex-direction:column;gap:8px;}
.rule-edit-row input,.rule-edit-row textarea,.rule-edit-row select{width:100%;padding:7px 10px;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r-sm);color:var(--text);font-family:'Inter',sans-serif;font-size:0.88rem;outline:none;transition:border-color 0.15s;}
.rule-edit-row input:focus,.rule-edit-row textarea:focus,.rule-edit-row select:focus{border-color:var(--accent);}
.rule-edit-row textarea{min-height:90px;resize:vertical;line-height:1.6;}
/* admin rule row (display mode) */
.rule-admin-row{background:var(--card2);border:1px solid var(--border2);border-radius:0.75rem;padding:16px;margin-bottom:8px;display:flex;align-items:flex-start;gap:10px;}
.rule-admin-title{font-size:1rem;font-weight:700;color:var(--text);line-height:1.4;}
.rule-admin-desc{font-size:0.85rem;color:var(--muted);margin-top:4px;line-height:1.6;}

/* ── SAÍDA TYPE BTNS ── */
.saida-type-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:6px;
  height:36px;padding:0 10px;border-radius:var(--r-sm);
  font-family:'Inter',sans-serif;font-size:0.78rem;font-weight:500;
  background:var(--card2);border:1px solid var(--border2);color:var(--muted);
  cursor:pointer;transition:all 0.12s;
}
.saida-type-btn.active{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent2);}
.saida-type-btn:hover:not(.active){border-color:var(--text2);color:var(--text2);}

/* ── ADMIN ── */
.badge-admin{background:rgba(239,68,68,0.1);color:#f87171;border:1px solid rgba(239,68,68,0.25);display:inline-flex;align-items:center;padding:2px 8px;border-radius:9999px;font-size:0.68rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;}
.sb-item.admin-item{color:#f87171;}
.sb-item.admin-item:hover{background:rgba(239,68,68,0.08);color:#fca5a5;}
.sb-item.admin-item.active{background:rgba(239,68,68,0.12);color:#f87171;border:1px solid rgba(239,68,68,0.25);}
.admin-section{margin-bottom:28px;}
.admin-section-title{font-size:0.72rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:8px;}
.admin-section-title::before{content:'';width:3px;height:14px;border-radius:2px;background:var(--accent);display:inline-block;}
.admin-card{background:var(--card);border:1px solid var(--border);border-radius:0.75rem;padding:20px;margin-bottom:12px;}
.admin-user-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.04);}
.admin-user-row:last-child{border-bottom:none;padding-bottom:0;}
.admin-user-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:0.8rem;font-weight:700;flex-shrink:0;}
.admin-user-name{font-weight:600;font-size:0.88rem;color:var(--text);flex:1;}
.admin-user-acts{display:flex;gap:6px;align-items:center;}
.btn-danger{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.25);color:#f87171;}
.btn-danger:hover{background:rgba(239,68,68,0.2);border-color:rgba(239,68,68,0.4);color:#fca5a5;}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.admin-loc-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04);}
.admin-loc-row:last-child{border-bottom:none;}
.admin-loc-name{flex:1;font-size:0.88rem;color:var(--text2);}
.admin-loc-edit{flex:1;}
.admin-loc-edit input{width:100%;height:32px;padding:0 8px;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r-sm);color:var(--text);font-family:'Inter',sans-serif;font-size:0.82rem;outline:none;}
.admin-loc-edit input:focus{border-color:var(--accent);}
#adminPage{display:none;}
.saida-admin-user{font-size:0.75rem;color:var(--muted);margin-top:2px;}
