/* public/assets/css/app.css */

/* Vazirmatn (Vazir family) - CDN */
@import url('https://cdn.jsdelivr.net/gh/rastikerdar/vazirmatn@v33.003/Vazirmatn-font-face.css');

/* If you want local font, put files in /assets/fonts/ and uncomment:
@font-face {
  font-family: 'Vazirmatn';
  src: url('../fonts/Vazirmatn.woff2') format('woff2'),
       url('../fonts/Vazirmatn.woff') format('woff');
  font-weight: 400;
  font-style: normal;
}
*/

:root{
  --bg:#0b0f14;
  --card:#111827;
  --border:#1f2937;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --primary:#3b82f6;
  --danger:#ef4444;
  --success:#22c55e;
  --shadow: 0 10px 25px rgba(0,0,0,.25);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Vazirmatn, Vazir, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1100px 600px at 80% 0%, rgba(59,130,246,.15), transparent 60%),
              radial-gradient(900px 600px at 20% 10%, rgba(34,197,94,.10), transparent 55%),
              var(--bg);
  color:var(--text);
  line-height:1.7;
}

a{color:var(--primary); text-decoration:none}
a:hover{text-decoration:underline}

.container{
  width: min(1050px, 92vw);
  margin: 0 auto;
  padding: 18px 0;
}

.topbar{
  position: sticky;
  top:0;
  z-index:10;
  backdrop-filter: blur(10px);
  background: rgba(17,24,39,.85);
  border-bottom:1px solid rgba(31,41,55,.7);
}

.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 10px 0;
}

.brand{
  font-weight:800;
  letter-spacing:.2px;
}

.nav{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.nav a{color:var(--text); opacity:.92}
.nav a.muted{color:var(--muted)}
.inline{display:inline}
.linklike{
  background:none;
  border:none;
  padding:0;
  cursor:pointer;
  color:var(--text);
  opacity:.92;
  font-family:inherit;
  font-size:1rem;
}
.linklike:hover{text-decoration:underline}

.card{
  background: rgba(17,24,39,.92);
  border: 1px solid rgba(31,41,55,.9);
  border-radius: 16px;
  padding: 16px;
  box-shadow: var(--shadow);
}
.card.soft{background: rgba(17,24,39,.65)}
.card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.h3{margin:0 0 10px 0; font-size: 1.15rem}
.h4{margin:0 0 10px 0; font-size: 1.02rem}
.small{font-size:.92rem}
.muted{color:var(--muted)}
code{
  background: rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.06);
  padding: 2px 6px;
  border-radius: 8px;
}

.form{
  display:flex;
  flex-direction:column;
  gap:10px;
}
label{font-weight:600}
input, select, textarea{
  width:100%;
  padding: 10px 12px;
  border-radius: 12px;
  border:1px solid rgba(31,41,55,.9);
  background: rgba(0,0,0,.25);
  color: var(--text);
  outline:none;
}
textarea{resize:vertical}
input:focus, select:focus, textarea:focus{
  border-color: rgba(59,130,246,.75);
  box-shadow: 0 0 0 3px rgba(59,130,246,.15);
}

.check{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:500;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(59,130,246,.7);
  background: linear-gradient(180deg, rgba(59,130,246,.95), rgba(37,99,235,.95));
  color:white;
  cursor:pointer;
  font-weight:700;
}
.btn:hover{filter:brightness(1.05)}
.btn.secondary{
  border:1px solid rgba(156,163,175,.35);
  background: rgba(0,0,0,.25);
  color: var(--text);
}
.btn.danger{
  border:1px solid rgba(239,68,68,.65);
  background: linear-gradient(180deg, rgba(239,68,68,.95), rgba(185,28,28,.95));
}
.actions{display:flex; gap:10px; flex-wrap:wrap}

.alert{
  margin: 12px 0;
  padding: 10px 12px;
  border-radius: 12px;
  border:1px solid rgba(31,41,55,.9);
  background: rgba(0,0,0,.25);
}
.alert.success{border-color: rgba(34,197,94,.6)}
.alert.error{border-color: rgba(239,68,68,.6)}

.row{display:flex; gap:12px; align-items:flex-start}
.col{flex:1}

.table-wrap{overflow:auto; border-radius: 12px; border:1px solid rgba(31,41,55,.9)}
.table{
  width:100%;
  border-collapse: collapse;
  min-width: 720px;
}
.table th, .table td{
  padding: 10px 12px;
  border-bottom:1px solid rgba(31,41,55,.9);
  text-align:right;
  vertical-align:top;
}
.table th{color:var(--muted); font-weight:700; background: rgba(0,0,0,.18)}
.table tr:hover td{background: rgba(255,255,255,.02)}

.badge{
  display:inline-flex;
  align-items:center;
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid rgba(156,163,175,.25);
  background: rgba(0,0,0,.18);
  font-size:.85rem;
}
.badge.pending{border-color: rgba(245,158,11,.55)}
.badge.approved{border-color: rgba(34,197,94,.55)}
.badge.rejected{border-color: rgba(239,68,68,.55)}
.badge.gray{border-color: rgba(156,163,175,.35)}

.tabs{display:flex; gap:8px; flex-wrap:wrap; margin: 10px 0 14px}
.tab{
  padding: 8px 12px;
  border-radius: 999px;
  border:1px solid rgba(31,41,55,.9);
  background: rgba(0,0,0,.2);
  color: var(--text);
}
.tab.active{
  border-color: rgba(59,130,246,.65);
  box-shadow: 0 0 0 3px rgba(59,130,246,.12);
}

.grid2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}

.kv{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(31,41,55,.7);
}
.kv .k{color:var(--muted)}
.kv .v{text-align:left}

.sep{
  border:none;
  border-top: 1px solid rgba(31,41,55,.9);
  margin: 14px 0;
}

.footer{
  padding: 20px 0;
  border-top: 1px solid rgba(31,41,55,.7);
  color: var(--muted);
  margin-top: 30px;
}

/* Mobile */
@media (max-width: 780px){
  .grid2{grid-template-columns: 1fr}
  .table{min-width: 620px}
  .topbar-inner{flex-direction:column; align-items:flex-start}
  .nav{justify-content:flex-start}
  .kv{flex-direction:column; align-items:flex-start}
  .kv .v{text-align:right}
}


/* v2 additions */
.badge.bell{ display:inline-block; margin-inline-start:8px; padding:2px 8px; border-radius:999px; background:#111; color:#fff; font-size:12px; line-height:18px; }
.grid2{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.grid3{ display:grid; grid-template-columns: 1fr 1fr 1fr; gap:12px; }
@media (max-width: 860px){
  .grid2,.grid3{ grid-template-columns: 1fr; }
}
.embed{ width:100%; overflow:hidden; border-radius:12px; border:1px solid #e6e6e6; background:#fff; }
.list{ margin:8px 0 0; padding:0 18px 0 0; }
.list li{ margin:6px 0; }
