@import url('theme-dark.css');
@import url('theme-light.css');
@import url('rtl.css');
@import url('sidebar.css');
@import url('login.css');
@import url('dashboard.css');
@import url('forms.css');
@import url('widgets.css');
@import url('print.css');

:root{
  --bg: #0b1220;
  --bg2:#0f172a;
  --panel:#111a2d;
  --panel2:#0f192b;
  --card: rgba(17,26,45,.84);
  --text:#e7edf5;
  --muted:#9da9bb;
  --line: rgba(255,255,255,.08);
  --primary:#d64b5d;
  --primary2:#9e3645;
  --accent:#355a91;
  --success:#1fb26b;
  --warning:#d6a11d;
  --danger:#d14f5a;
  --shadow: 0 24px 72px rgba(0,0,0,.32);
  --radius: 26px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Vazirmatn","IRANSansX","Segoe UI",Tahoma,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(214,75,93,.16), transparent 16%),
    radial-gradient(circle at left top, rgba(53,90,145,.16), transparent 18%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg2) 100%);
}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
img{max-width:100%;display:block}
.hidden{display:none!important}

.app-bg{
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 12% 12%, rgba(214,75,93,.08), transparent 18%),
    radial-gradient(circle at 82% 18%, rgba(53,90,145,.10), transparent 14%),
    radial-gradient(circle at 50% 86%, rgba(255,255,255,.05), transparent 24%);
  pointer-events:none;
  z-index:0;
}

.glass{
  background:rgba(13,20,34,.64);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
}

.app-shell-wrap{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:300px 1fr;
  min-height:100vh;
}

.main-panel{min-width:0;display:flex;flex-direction:column}
.content-panel{padding:22px;display:flex;flex-direction:column;gap:16px}
.flash{
  border-radius:18px;padding:14px 16px;font-weight:700
}
.flash-success{background:rgba(31,178,107,.14);border:1px solid rgba(31,178,107,.28)}
.flash-danger{background:rgba(209,79,90,.14);border:1px solid rgba(209,79,90,.28)}
.flash-warning{background:rgba(214,161,29,.14);border:1px solid rgba(214,161,29,.28)}

.panel,.card{
  border-radius:var(--radius);
  background:var(--card);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.panel{padding:18px}
.panel-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px;flex-wrap:wrap}
.panel-title{font-size:20px;font-weight:900;letter-spacing:-.04em}
.panel-sub,.crumb-sub,.auth-sub,.sub{color:var(--muted);font-size:13px;line-height:1.9}
.panel-actions{display:flex;gap:8px;flex-wrap:wrap}
.subsection-title{font-size:15px;font-weight:800;margin:0 0 10px}

.chip,.chip:visited{
  height:40px;padding:0 14px;border-radius:14px;
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:var(--text)
}
.chip input{
  background:transparent;border:none;outline:none;color:var(--text);min-width:240px
}
.primary-btn,.ghost-btn,.side-action,.menu-toggle,.icon-btn{
  border:none;border-radius:16px;cursor:pointer;transition:.18s ease
}
.primary-btn{
  padding:12px 18px;
  background:linear-gradient(135deg,var(--primary),var(--primary2));
  color:#fff;font-weight:800;box-shadow:0 14px 28px rgba(214,75,93,.24)
}
.ghost-btn,.side-action,.menu-toggle,.icon-btn{
  background:rgba(255,255,255,.05);
  color:var(--text);
  border:1px solid rgba(255,255,255,.08)
}
.ghost-btn{padding:12px 18px;font-weight:700}
.primary-btn:hover,.ghost-btn:hover,.side-action:hover,.menu-toggle:hover,.icon-btn:hover{transform:translateY(-1px)}
.danger{color:#ffd6db}

.table-wrap{
  overflow:auto;border-radius:20px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03)
}
.data-table{
  width:100%;border-collapse:collapse;min-width:980px
}
.data-table th,.data-table td{
  padding:12px 10px;border-bottom:1px solid rgba(255,255,255,.06);text-align:right;font-size:13px;vertical-align:top
}
.data-table th{
  position:sticky;top:0;z-index:2;background:rgba(13,20,34,.96);color:#dfe6f1;font-size:12px;letter-spacing:.06em;text-transform:uppercase
}
.data-table tr:hover td{background:rgba(255,255,255,.02)}
.table-empty,.empty-state{
  padding:18px;color:var(--muted);text-align:center
}

.status{
  display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:800
}
.status-new,.status-draft{background:rgba(255,255,255,.07)}
.status-assigned,.status-pending{background:rgba(214,161,29,.16);color:#ffd88f}
.status-approved,.status-closed,.status-printed{background:rgba(31,178,107,.16);color:#8ef1bc}
.status-rejected{background:rgba(209,79,90,.16);color:#ffb8c0}
.status-active{background:rgba(53,90,145,.16);color:#c6dcff}

.modal,.notif-panel{
  position:fixed;top:16px;left:16px;z-index:50;width:min(390px,calc(100vw - 32px));
  display:none
}
.notif-panel{right:16px;left:auto;top:78px;padding:16px;border-radius:24px}
.notif-panel.open{display:block}
.panel-head .icon-btn{width:40px;height:40px}
.notif-list{display:flex;flex-direction:column;gap:10px;max-height:62vh;overflow:auto}
.notif-item{
  padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)
}
.notif-item strong{display:block;margin-bottom:4px}
.notif-item small{display:block;color:var(--muted);line-height:1.8}

.form-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px
}
.form-grid label,.auth-form label,.setup-form label,.record-form label{
  display:flex;flex-direction:column;gap:8px;font-size:13px;font-weight:800;color:#dbe5f3
}
.form-grid .full{grid-column:1/-1}
.form-grid input,.form-grid select,.form-grid textarea,
.auth-form input,.setup-form input, .record-form input,.record-form select,.record-form textarea,
.report-builder input,.report-builder select,.report-builder textarea{
  width:100%;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(9,14,25,.92);
  color:var(--text);
  padding:12px 14px;
  outline:none;
}
.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus,
.auth-form input:focus,.setup-form input:focus,.record-form input:focus,.record-form select:focus,.record-form textarea:focus{
  border-color:rgba(214,75,93,.55);
  box-shadow:0 0 0 4px rgba(214,75,93,.14)
}
.form-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.record-form .form-grid{margin-bottom:10px}

.kpi-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px
}
.kpi-card{
  padding:16px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);min-height:122px;display:flex;flex-direction:column;justify-content:space-between
}
.kpi-label{color:var(--muted);font-size:13px}
.kpi-value{font-size:32px;font-weight:900;line-height:1;letter-spacing:-.04em}
.kpi-note{font-size:12px;color:#b7c1d3}
.kpi-icon{
  width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.06)
}

.chart-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:12px
}
.chart-card{
  min-height:310px;display:flex;flex-direction:column;justify-content:space-between;padding:16px;border-radius:24px
}
.chart-box{height:220px;position:relative}
.chart-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.legend-pill{
  padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.05);font-size:12px;color:#dce4f2
}
.timeline,.activity-list,.presence-list,.preset-list{
  display:flex;flex-direction:column;gap:10px
}
.timeline-item,.activity-item,.presence-item,.preset-item{
  padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)
}
.timeline-item strong,.activity-item strong,.presence-item strong,.preset-item strong{display:block;margin-bottom:4px}
.timeline-item small,.activity-item small,.presence-item small,.preset-item small{display:block;color:var(--muted);line-height:1.8}
.widget-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:10px 0 12px
}
.widget-check{
  display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)
}

.auth-shell{
  min-height:100vh;display:grid;place-items:center;overflow:hidden
}
.auth-bg{
  position:fixed;inset:0;background:
    radial-gradient(circle at top right, rgba(214,75,93,.22), transparent 14%),
    radial-gradient(circle at left bottom, rgba(53,90,145,.16), transparent 18%),
    linear-gradient(180deg,#070d17 0%, #0b1220 100%);
  z-index:0
}
.auth-wrap{position:relative;z-index:1;width:min(1120px,calc(100vw - 28px));padding:20px}
.auth-card{
  display:grid;grid-template-columns:1.1fr .9fr;overflow:hidden;border-radius:32px;box-shadow:0 34px 90px rgba(0,0,0,.42)
}
.auth-hero{
  padding:34px;background:
    linear-gradient(135deg, rgba(14,21,36,.96), rgba(30,18,26,.94) 60%, rgba(18,26,41,.93)),
    rgba(255,255,255,.04);
  border-inline-end:1px solid rgba(255,255,255,.08)
}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.auth-mark{
  width:64px;height:64px;border-radius:20px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary2));
  box-shadow:0 18px 36px rgba(214,75,93,.22)
}
.auth-mark img{width:44px;height:44px;object-fit:contain}
.auth-title{font-size:20px;font-weight:900}
.auth-sub{font-size:13px;color:var(--muted);margin-top:4px}
.auth-hero h1{font-size:40px;letter-spacing:-.05em;margin:10px 0}
.auth-hero p{color:#c8d3e6;line-height:2;max-width:520px}
.auth-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.auth-pills span{
  padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:13px
}
.auth-form,.setup-form{
  padding:28px;background:rgba(8,13,22,.94);display:flex;flex-direction:column;gap:12px
}
.auth-form input,.setup-form input{background:rgba(255,255,255,.05)}
.auth-note{color:var(--muted);font-size:12px;line-height:1.8;margin-top:4px}
.login-card .auth-form{min-height:100%}
.setup-card .setup-form{grid-template-columns:repeat(2,minmax(0,1fr));display:grid;gap:12px}
.setup-card .setup-form .primary-btn{grid-column:1/-1}
.setup-card .auth-hero h1{font-size:34px}

.sidebar{
  position:sticky;top:0;height:100vh;overflow:auto;padding:16px;display:flex;flex-direction:column;gap:14px
}
.brand-panel{display:flex;align-items:center;gap:12px;padding:12px 12px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.brand-mark{width:54px;height:54px;border-radius:18px;overflow:hidden;background:linear-gradient(135deg,var(--primary),var(--primary2))}
.brand-mark img{width:100%;height:100%;object-fit:cover}
.brand-name{font-size:19px;font-weight:900}
.brand-sub{font-size:12px;color:var(--muted);margin-top:4px}
.sidebar-search{padding:0 4px}
.sidebar-search input{
  width:100%;border-radius:16px;padding:12px 14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:var(--text)
}
.sidebar-nav{display:flex;flex-direction:column;gap:8px;min-height:0}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:12px 12px;border-radius:16px;border:1px solid transparent;background:transparent;color:var(--text);transition:.18s ease
}
.nav-item:hover{background:rgba(255,255,255,.05);transform:translateX(-2px)}
.nav-item.active{background:linear-gradient(135deg,rgba(214,75,93,.24),rgba(53,90,145,.12));border-color:rgba(214,75,93,.22);box-shadow:0 12px 24px rgba(0,0,0,.12)}
.nav-icon{width:28px;height:28px;display:grid;place-items:center;opacity:.9}
.nav-icon svg{width:24px;height:24px}
.nav-label{font-weight:700}
.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}
.side-action{
  display:flex;align-items:center;gap:10px;justify-content:flex-start;padding:12px 14px
}
.side-action svg,.chip svg,.menu-toggle svg,.icon-btn svg{width:18px;height:18px}
.side-action.danger{color:#ffc8cf}
.topbar{
  display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;position:sticky;top:0;z-index:10
}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.menu-toggle{width:44px;height:44px;display:grid;place-items:center}
.crumb-title{font-size:22px;font-weight:900;letter-spacing:-.04em}
.crumb-sub{font-size:12px}
.search-chip{min-width:320px}
.user-chip{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.user-avatar{
  width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary2));font-weight:900
}
.user-name{font-weight:900}
.user-role{font-size:12px;color:var(--muted)}
.search-suggest{
  position:absolute;z-index:99;min-width:280px;max-width:420px;background:rgba(12,18,32,.98);border:1px solid rgba(255,255,255,.08);border-radius:18px;box-shadow:var(--shadow);overflow:hidden
}
.search-suggest .item{padding:10px 12px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.06)}
.search-suggest .item:hover{background:rgba(255,255,255,.04)}
.search-suggest .item.add{color:#ffd7dd}
.print-page{
  background:#fff;color:#111; padding:24px;border-radius:18px
}
.print-page *{color:#111!important}
.print-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:12px;border-bottom:2px solid #e5e7eb;margin-bottom:14px}
.print-title{font-size:22px;font-weight:900}
.print-meta{font-size:12px;line-height:1.8;color:#4b5563}
.print-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.print-box{border:1px solid #d1d5db;border-radius:14px;padding:12px;min-height:72px}
.print-signs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.sign-box{border:1px dashed #cbd5e1;border-radius:14px;min-height:110px;display:flex;align-items:flex-end;justify-content:center;padding:12px;font-size:12px}
@media (max-width: 1180px){
  .app-shell-wrap{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto}
  .chart-grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .auth-card{grid-template-columns:1fr}
  .search-chip{min-width:220px}
}
@media (max-width: 760px){
  .content-panel{padding:14px}
  .kpi-grid,.form-grid,.widget-grid,.setup-card .setup-form{grid-template-columns:1fr}
  .topbar{padding:12px 14px}
  .user-chip{width:100%;justify-content:flex-start}
  .search-chip{min-width:100%;width:100%}
  .search-chip input{min-width:0}
  .data-table{min-width:820px}
}
