@font-face {
	font-family: IRANyekan;
	font-style: normal;
	font-weight: Bold;
	src: url('fonts/eot/IRANYekanWebBold.eot');
	src: url('fonts/eot/IRANYekanWebBold.eot?#iefix') format('embedded-opentype'),  /* IE6-8 */
		 url('fonts/woff/IRANYekanWebBold.woff') format('woff'),  /* FF3.6+, IE9, Chrome6+, Saf5.1+*/
		 url('fonts/woff2/IRANYekanWebBold.woff2') format('woff2'),  /* FF39+,Chrome36+, Opera24+*/
		 url('fonts/ttf/IRANYekanWebBold.ttf') format('truetype');
}

@font-face {
	font-family: IRANyekan;
	font-style: normal;
	font-weight: 100;
	src: url('fonts/eot/IRANYekanWebthin.eot');
	src: url('fonts/eot/IRANYekanWebthin.eot?#iefix') format('embedded-opentype'),  /* IE6-8 */
		 url('fonts/woff/IRANYekanWebthin.woff') format('woff'),  /* FF3.6+, IE9, Chrome6+, Saf5.1+*/
		 url('fonts/woff2/IRANYekanWebthin.woff2') format('woff2'),  /* FF39+,Chrome36+, Opera24+*/
		 url('fonts/ttf/IRANYekanWebthin.ttf') format('truetype');
}

@font-face {
	font-family: IRANyekan;
	font-style: normal;
	font-weight: 300;
	src: url('fonts/eot/IRANYekanWeblight.eot');
	src: url('fonts/eot/IRANYekanWeblight.eot?#iefix') format('embedded-opentype'),  /* IE6-8 */
		 url('fonts/woff/IRANYekanWeblight.woff') format('woff'),  /* FF3.6+, IE9, Chrome6+, Saf5.1+*/
		 url('fonts/woff2/IRANYekanWeblight.woff2') format('woff2'),  /* FF39+,Chrome36+, Opera24+*/
		 url('fonts/ttf/IRANYekanWeblight.ttf') format('truetype');
}

@font-face {
	font-family: IRANyekan;
	font-style: normal;
	font-weight: normal;
	src: url('fonts/eot/IRANYekanWebRegular.eot');
	src: url('fonts/eot/IRANYekanWebRegular.eot?#iefix') format('embedded-opentype'),  /* IE6-8 */
		 url('fonts/woff/IRANYekanWebRegular.woff') format('woff'),  /* FF3.6+, IE9, Chrome6+, Saf5.1+*/
		 url('fonts/woff2/IRANYekanWebRegular.woff2') format('woff2'), /* FF39+,Chrome36+, Opera24+*/
		 url('fonts/ttf/IRANYekanWebRegular.ttf') format('truetype');
}

@font-face {
	font-family: IRANyekan;
	font-style: normal;
	font-weight: 500;
	src: url('fonts/eot/IRANYekanWebMedium.eot');
	src: url('fonts/eot/IRANYekanWebMedium.eot?#iefix') format('embedded-opentype'),  /* IE6-8 */
		 url('fonts/woff/IRANYekanWebMedium.woff') format('woff'),  /* FF3.6+, IE9, Chrome6+, Saf5.1+*/
		 url('fonts/woff2/IRANYekanWebMedium.woff2') format('woff2'),  /* FF39+,Chrome36+, Opera24+*/
		 url('fonts/ttf/IRANYekanWebMedium.ttf') format('truetype');
}

@font-face {
	font-family: IRANyekan;
	font-style: normal;
	font-weight: 800;
	src: url('fonts/eot/IRANYekanWebextraBold.eot');
	src: url('fonts/eot/IRANYekanWebextraBold.eot?#iefix') format('embedded-opentype'),  /* IE6-8 */
		 url('fonts/woff/IRANYekanWebextraBold.woff') format('woff'),  /* FF3.6+, IE9, Chrome6+, Saf5.1+*/
		 url('fonts/woff2/IRANYekanWebextraBold.woff2') format('woff2'),  /* FF39+,Chrome36+, Opera24+*/
		 url('fonts/ttf/IRANYekanWebextraBold.ttf') format('truetype');
}

@font-face {
	font-family: IRANyekan;
	font-style: normal;
	font-weight: 850;
	src: url('fonts/eot/IRANYekanWebblack.eot');
	src: url('fonts/eot/IRANYekanWebblack.eot?#iefix') format('embedded-opentype'),  /* IE6-8 */
		 url('fonts/woff/IRANYekanWebblack.woff') format('woff'),  /* FF3.6+, IE9, Chrome6+, Saf5.1+*/
		 url('fonts/woff2/IRANYekanWebblack.woff2') format('woff2'),  /* FF39+,Chrome36+, Opera24+*/
		 url('fonts/ttf/IRANYekanWebblack.ttf') format('truetype');
}

@font-face {
	font-family: IRANyekan;
	font-style: normal;
	font-weight: 900;
	src: url('fonts/eot/IRANYekanWebextrablack.eot');
	src: url('fonts/eot/IRANYekanWebextrablack.eot?#iefix') format('embedded-opentype'),  /* IE6-8 */
		 url('fonts/woff/IRANYekanWebextrablack.woff') format('woff'),  /* FF3.6+, IE9, Chrome6+, Saf5.1+*/
		 url('fonts/woff2/IRANYekanWebextrablack.woff2') format('woff2'),  /* FF39+,Chrome36+, Opera24+*/
		 url('fonts/ttf/IRANYekanWebextrablack.ttf') format('truetype');
}

:root{
  --card:#ffffff;
  --muted:#6b7280;
  --line:#e5e7eb;
  --shadow:0 2px 12px rgba(0,0,0,.15);
  --primary:#2563eb;
  --success:#059669;
  --warning:#f59e0b;
  --danger:#dc2626;
  --font-family:'IRANyekan','Vazir','Tahoma',system-ui,sans-serif;
}
*{box-sizing:border-box;font-family:var(--font-family)}
html,body{height:100%}
body{margin:0;background:#ede7dd;font-family:var(--font-family);color:#111827;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
input,button,textarea,select{font-family:var(--font-family)}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* لاگین با طراحی جدید */
/* ═══════════════════════════════════════════════════════════════════════════ */
#loginOverlay{
  position:fixed;
  inset:0;
  background:linear-gradient(135deg, #1e3a5f 0%, #2563eb 50%, #0ea5e9 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:99999;
}
#loginCard{
  width:min(94vw, 420px);
  background:rgba(255,255,255,0.98);
  border-radius:24px;
  box-shadow:0 25px 80px rgba(0,0,0,0.4);
  padding:32px 28px;
  direction:rtl;
  backdrop-filter:blur(20px);
  animation:slideUp 0.4s ease;
}
@keyframes slideUp {
  from { transform: translateY(30px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.login-logo{font-size:56px;text-align:center;margin-bottom:8px;filter:drop-shadow(0 4px 12px rgba(37,99,235,0.3))}
.login-header{text-align:center;margin-bottom:24px}
.login-logo-img{width:110px;margin-bottom:16px;}
#loginCard h4{margin:0 0 6px;text-align:center;font-size:22px;color:#1e3a5f}
.login-subtitle{text-align:center;color:#6b7280;font-size:13px;margin:0 0 20px}
.auth-step{animation:fadeIn 0.3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.primary-btn{width:100%;margin-top:16px;padding:14px;border:0;border-radius:12px;background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;cursor:pointer;font-size:16px;font-weight:600;transition:all 0.2s;box-shadow:0 4px 15px rgba(37,99,235,0.4)}
.primary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,99,235,0.5)}
.primary-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}
.secondary-btn{width:100%;margin-top:10px;padding:12px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;color:#374151;cursor:pointer;font-size:14px;font-weight:500;transition:all 0.2s}
.secondary-btn:hover{border-color:#2563eb;color:#2563eb}
.link-btn{background:none;border:none;color:#2563eb;cursor:pointer;font-size:13px;padding:8px 12px;transition:all 0.2s}
.link-btn:hover{text-decoration:underline}
.link-btn:disabled{color:#9ca3af;cursor:not-allowed}
.login-divider{display:flex;align-items:center;margin:20px 0;gap:12px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:#e5e7eb}
.login-divider span{color:#9ca3af;font-size:12px}
.otp-actions{display:flex;justify-content:space-between;margin-top:12px}
.required{color:#dc2626}
.optional{color:#9ca3af;font-size:11px}
#loginSuccess{color:#059669;font-size:13px;margin-top:12px;text-align:center;background:#ecfdf5;padding:10px;border-radius:8px}
#loginCard label{display:block;font-size:13px;margin:14px 0 6px;color:#374151;font-weight:500}
#loginCard input{
  width:100%;
  border:2px solid #e5e7eb;
  border-radius:12px;
  padding:12px 14px;
  font-size:15px;
  transition:all 0.2s;
}
#loginCard input:focus{border-color:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,0.1);outline:none}
#loginCard button{
  width:100%;
  margin-top:20px;
  padding:14px;
  border:0;
  border-radius:12px;
  background:linear-gradient(135deg,#2563eb,#1e40af);
  color:#fff;
  cursor:pointer;
  font-size:16px;
  font-weight:600;
  transition:all 0.2s;
  box-shadow:0 4px 15px rgba(37,99,235,0.4);
}
#loginCard button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,99,235,0.5)}
#loginErr{color:#dc2626;font-size:13px;display:none;margin-top:12px;text-align:center;background:#fef2f2;padding:10px;border-radius:8px}

/* حساب‌های آزمایشی */
.demo-accounts{margin-top:20px;padding-top:16px;border-top:1px dashed #e5e7eb}
.demo-title{font-size:12px;color:#6b7280;margin-bottom:10px;text-align:center}
.demo-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f8fafc;border-radius:8px;margin-bottom:6px;font-size:12px;direction:ltr}
.demo-role{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;color:#fff}
.demo-role.admin{background:linear-gradient(135deg,#dc2626,#b91c1c)}
.demo-role.manager{background:linear-gradient(135deg,#f59e0b,#d97706)}
.demo-role.user{background:linear-gradient(135deg,#2563eb,#1d4ed8)}

/* لاگین موبایل */
@media (max-width:480px){
  #loginCard{padding:24px 20px;border-radius:20px}
  .login-logo{font-size:44px}
  #loginCard h4{font-size:18px}
  .login-subtitle{font-size:12px;margin-bottom:16px}
  #loginCard label{font-size:12px;margin:10px 0 4px}
  #loginCard input{padding:10px 12px;font-size:14px}
  #loginCard button{padding:12px;font-size:15px}
  .demo-accounts{margin-top:16px;padding-top:12px}
  .demo-item{padding:6px 10px;font-size:11px;gap:8px}
  .demo-role{padding:3px 8px;font-size:10px}
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* منوی کشویی موبایل */
/* ═══════════════════════════════════════════════════════════════════════════ */
.menu-toggle{
  display:none;
  width:40px;
  height:40px;
  border:none;
  background:rgba(255,255,255,0.15);
  color:#fff;
  font-size:24px;
  border-radius:10px;
  cursor:pointer;
  transition:all 0.2s;
}
.menu-toggle:hover{background:rgba(255,255,255,0.25)}

.side-menu{
  position:fixed;
  top:0;
  right:-300px;
  width:280px;
  height:100vh;
  background:linear-gradient(180deg,#1e3a5f 0%,#0f172a 100%);
  z-index:2001;
  transition:right 0.3s ease;
  display:flex;
  flex-direction:column;
  box-shadow:-5px 0 30px rgba(0,0,0,0.4);
}
.side-menu.open{right:0}

.side-menu-header{
  display:flex;
  align-items:center;
  gap:12px;
  padding:20px 16px;
  border-bottom:1px solid rgba(255,255,255,0.1);
  background:rgba(0,0,0,0.2);
}
#sideUserAvatar{
  font-size:36px;
  background:rgba(255,255,255,0.1);
  width:50px;
  height:50px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
}
.side-user-info{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:4px;
  color:#fff;
}
#sideUserName{font-weight:600;font-size:15px}
#sideUserRole{font-size:11px;align-self:flex-start}
.close-menu-btn{
  width:36px;
  height:36px;
  border:none;
  background:rgba(255,255,255,0.1);
  color:#fff;
  font-size:20px;
  border-radius:50%;
  cursor:pointer;
}
.close-menu-btn:hover{background:rgba(255,255,255,0.2)}

.side-menu-nav{
  flex:1;
  padding:16px 0;
  overflow-y:auto;
}
.side-menu-item{
  width:100%;
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 20px;
  border:none;
  background:transparent;
  color:#fff;
  font-size:14px;
  font-weight:500;
  cursor:pointer;
  transition:all 0.2s;
  text-align:right;
}
.side-menu-item:hover{background:rgba(255,255,255,0.1)}
.side-menu-item.logout-item{color:#f87171}
.side-menu-item.logout-item:hover{background:rgba(248,113,113,0.15)}
.side-menu-divider{
  height:1px;
  background:rgba(255,255,255,0.1);
  margin:12px 16px;
}

.menu-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.5);
  z-index:2000;
  opacity:0;
  visibility:hidden;
  transition:all 0.3s;
}
.menu-overlay.open{opacity:1;visibility:visible}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* نوار بالا */
/* ═══════════════════════════════════════════════════════════════════════════ */
#topBar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  height:50px;
  background:linear-gradient(135deg,#1e3a5f,#2563eb);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 20px;
  z-index:1000;
  box-shadow:0 2px 20px rgba(0,0,0,0.2);
}
.user-info{display:flex;align-items:center;gap:12px;color:#fff}
#userAvatar{font-size:24px;background:rgba(255,255,255,0.15);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}
#userName{font-weight:600;font-size:14px}
.role-badge{
  padding:4px 12px;
  border-radius:20px;
  font-size:11px;
  font-weight:600;
  background:rgba(255,255,255,0.2);
}
.role-badge.role-admin{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 2px 8px rgba(220,38,38,0.4)}
.role-badge.role-manager{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px rgba(245,158,11,0.4)}
.role-badge.role-user{background:rgba(255,255,255,0.25)}

.top-actions{display:flex;gap:10px}
.top-btn{
  padding:8px 16px;
  border:none;
  border-radius:10px;
  background:rgba(255,255,255,0.15);
  color:#fff;
  cursor:pointer;
  font-size:13px;
  font-weight:500;
  transition:all 0.2s;
  display:flex;
  align-items:center;
  gap:6px;
  width: auto;
}
.top-btn:hover{background:rgba(255,255,255,0.25);transform:translateY(-1px)}
.top-btn.logout-btn{background:rgba(220,38,38,0.3)}
.top-btn.logout-btn:hover{background:rgba(220,38,38,0.5)}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* تنظیمات اصلی اپ */
/* ═══════════════════════════════════════════════════════════════════════════ */
#app{display:flex;height:100vh;width:100vw;overflow:hidden;visibility:hidden;padding-top:50px}
#viewport{flex:1;position:relative;background:#2a2d35;min-width:0;border-inline-end:1px solid var(--line)}
#ui{flex:0 0 520px;max-width:520px;min-width:320px;padding:12px 14px;overflow:auto;background:#fff;scrollbar-width:thin;scrollbar-color:#d1d5db #f9fafb}
#ui::-webkit-scrollbar{width:8px}
#ui::-webkit-scrollbar-track{background:#f9fafb}
#ui::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}
#ui::-webkit-scrollbar-thumb:hover{background:#9ca3af}
h3{margin:0 0 8px}
.header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.header-row h3{margin:0}
.header-btns{display:flex;gap:8px;align-items:center}
.theme-btn{width:40px;height:40px;border-radius:50%;border:2px solid var(--line);background:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.3s ease;box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.theme-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(0,0,0,0.15)}
.reset-btn{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff}
.reset-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}
details{background:#fafafa;border:1px solid var(--line);border-radius:10px;margin:8px 0;transition:all 0.2s ease}
details:hover{background:#f5f5f5;border-color:#d1d5db}
details[open]{background:#fff;box-shadow:0 1px 3px rgba(0,0,0,0.05)}
summary{padding:10px 12px;cursor:pointer;font-weight:700;user-select:none;list-style:none;position:relative}
summary::-webkit-details-marker{display:none}
summary::marker{display:none}
summary::after{content:"▼";float:left;margin-left:8px;transition:transform 0.2s ease;font-size:10px;color:var(--muted)}
details[open] summary::after{transform:rotate(180deg)}
.section-body{padding:10px 12px 12px}
label{display:block;margin-top:6px;font-size:13px}
input,select,button{width:100%;border:1px solid #d1d5db;border-radius:10px;padding:8px 10px;font-size:16px;background:#fff;transition:all 0.2s ease;touch-action:manipulation}
input:focus,select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,0.1)}
input[type="number"]{-moz-appearance:textfield;appearance:textfield}
input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
button{cursor:pointer;font-weight:500;transition:all 0.2s ease}
button:hover{background:#f9fafb;transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,0.1)}
button:active{transform:translateY(0)}
input[type="checkbox"]{width:auto;cursor:pointer}
input[type="number"]{direction:ltr;text-align:left}
input[type="hidden"]{display:none !important}
.grid-two{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.grid-three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.row{display:flex;align-items:center;gap:8px}
#metrics,#tests,#bom,#details,#constraints,#counts{font-size:12px;line-height:1.9;margin:8px 0}
#bom,#constraints,#details,#counts{background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px}
#bom table,#counts table{width:100%;border-collapse:collapse;font-size:12px}
#bom th,#bom td,#counts th,#counts td{border-bottom:1px dashed var(--line);padding:4px 6px;text-align:right}
#bom tfoot td{font-weight:700;background:#f9fafb}
#bom thead,#counts thead{background:#f9fafb}
#bom th,#counts th{font-weight:600;color:#374151}
#tests{display:none}
#tests.pass{border:1px solid #86efac;background:#ecfdf5}
#tests.fail{border:1px solid #fecaca;background:#fef2f2}
.muted{color:var(--muted)}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.actions button{flex:1;min-width:120px}
.sticky-actions{bottom:0;background:linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.98) 18%);padding-top:8px;position:sticky}
.mobile-toggle-btn{display:none}
.sticky-actions-content{transition:max-height 0.3s ease, opacity 0.3s ease;max-height:none;opacity:1;padding:0}
.errbar{position:fixed;left:0;right:0;top:50px;background:#fee2e2;color:#991b1b;padding:8px 12px;font-size:12px;z-index:999;display:none}

#viewport canvas{display:block;width:100% !important;height:100% !important;touch-action:none}
#viewport{position:relative;overflow:hidden}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* پنل مدیریت کاربران */
/* ═══════════════════════════════════════════════════════════════════════════ */
.admin-header{background:linear-gradient(135deg,#dc2626,#b91c1c) !important}
.admin-container{max-width:1000px}
.admin-section{margin-bottom:24px;padding:20px;background:#f8fafc;border-radius:12px}
.users-table{width:100%;border-collapse:collapse}
.users-table th{background:#1e3a5f;color:#fff;padding:12px;text-align:right;font-weight:600}
.users-table td{padding:12px;border-bottom:1px solid #e5e7eb;vertical-align:middle}
.users-table tbody tr:hover{background:#f1f5f9}
.role-select{width:auto;padding:6px 10px;border-radius:8px;font-size:13px}
.delete-user-btn{width:auto;padding:6px 12px;background:#fee2e2;border:none;border-radius:8px;cursor:pointer;font-size:16px}
.delete-user-btn:hover{background:#fecaca}
.add-user-btn{margin-top:16px;padding:12px 24px;background:linear-gradient(135deg,#059669,#047857);color:#fff;border:none;border-radius:10px;font-weight:600;width:auto}
.add-user-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(5,150,105,0.4)}
button.edit-user-btn {
  width: auto;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* پنل تنظیمات پنل خورشیدی */
/* ═══════════════════════════════════════════════════════════════════════════ */
.panel-settings-header{background:linear-gradient(135deg,#f59e0b,#d97706) !important}
.panel-settings-container{max-width:600px}
.base-settings-header{background:linear-gradient(135deg,#059669,#047857) !important}
.base-settings-container{max-width:1100px}
.panel-models-table th{background:#7c3aed !important}
.use-model-btn{width:auto;padding:6px 10px;background:#ecfdf5;border:none;border-radius:8px;cursor:pointer;font-size:14px;margin-left:6px}
.use-model-btn:hover{background:#d1fae5}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* ریسپانسیو موبایل */
/* ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width:900px){
  /* نوار بالا - منوی همبرگری */
  #topBar{
    height:56px;
    flex-direction:row;
    padding:0 12px;
    gap:12px;
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:1000;
    justify-content:space-between;
  }
  .menu-toggle{display:flex;align-items:center;justify-content:center}
  .user-info{
    flex:1;
    justify-content:center;
    padding:0;
    border-bottom:none;
  }
  #userAvatar{font-size:18px;width:28px;height:28px}
  #userName{font-size:12px}
  .role-badge{font-size:9px;padding:2px 6px}
  .desktop-menu{display:none !important}
  #app{flex-direction:column;padding-top:56px}
  #viewport{order:-1;height:45vh;min-height:280px;width:100vw;border-inline-end:none;border-block-end:1px solid var(--line)}
  #ui{flex:unset;max-width:none;width:100vw;border-inline-start:none;padding:10px 12px;max-height:calc(55vh - 60px);overflow-y:auto;-webkit-overflow-scrolling:touch}
  body{overflow:auto}
  h3{font-size:18px;margin:0 0 12px}
  details{margin:6px 0;border-radius:8px}
  summary{padding:12px 14px;font-size:14px}
  .section-body{padding:12px 14px}
  label{font-size:14px;margin-top:8px}
  input,select,button{font-size:14px;padding:10px 12px;border-radius:8px}
  input[type="number"]{direction:ltr;text-align:left}
  input[type="hidden"]{display:none !important}
  .grid-two,.grid-three{grid-template-columns:1fr;gap:10px}
  #metrics,#tests,#bom,#details,#constraints,#counts{font-size:13px;margin:10px 0;padding:10px}
  #bom table,#counts table{font-size:13px}
  #bom th,#bom td,#counts th,#counts td{padding:6px 8px}
  .actions{flex-direction:column;gap:8px}
  .actions button{width:100%;padding:12px;font-size:14px;font-weight:600}
  .sticky-actions{position:relative;background:#fff;border-top:2px solid var(--line);margin-top:16px;padding:0}
  .mobile-toggle-btn{display:flex;width:100%;align-items:center;justify-content:center;gap:8px;padding:14px 16px;background:#f9fafb;border:none;border-bottom:1px solid var(--line);cursor:pointer;font-size:15px;font-weight:600;color:#374151;transition:background 0.2s ease;-webkit-tap-highlight-color:transparent}
  .mobile-toggle-btn:hover{background:#f3f4f6}
  .mobile-toggle-btn:active{background:#e5e7eb}
  .toggle-icon{transition:transform 0.3s ease;font-size:14px;color:var(--muted);display:inline-block}
  .toggle-text{font-weight:600}
  .sticky-actions.collapsed .toggle-icon{transform:rotate(-90deg)}
  .sticky-actions-content{max-height:0;overflow:hidden;opacity:0;transition:max-height 0.3s ease, opacity 0.3s ease, padding 0.3s ease;padding:0}
  .sticky-actions:not(.collapsed) .sticky-actions-content{max-height:1000px;opacity:1;padding:12px 14px}
  .sticky-actions.collapsed .sticky-actions-content{padding:0}
  
  /* پنل مدیریت و جداول */
  .admin-section{padding:12px}
  .users-table{font-size:11px}
  .users-table th,.users-table td{padding:6px 4px}
  .users-table th:nth-child(4),.users-table td:nth-child(4){display:none}
  .role-select{font-size:11px;padding:4px 6px}
  .delete-user-btn{padding:4px 8px;font-size:14px}
  
  /* مودال‌ها */
  .report-container{max-width:100%;margin:10px;border-radius:12px;max-height:calc(100vh - 20px)}
  .report-header{padding:14px 16px;border-radius:12px 12px 0 0}
  .report-header h2{font-size:16px}
  .report-content{padding:16px}
  .report-actions{padding:12px 16px;flex-direction:column;gap:8px}
  .report-actions button{width:100%;padding:12px}
  
  /* سفارشات */
  .orders-stats{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat-card{padding:12px}
  .stat-value{font-size:18px}
  .orders-table{font-size:11px}
  .orders-table th,.orders-table td{padding:6px 4px}
  .orders-table th:nth-child(4),.orders-table td:nth-child(4),
  .orders-table th:nth-child(7),.orders-table td:nth-child(7){display:none}
  
  /* سیستم سفارش */
  .order-options{grid-template-columns:1fr}
  .option-card{padding:16px}
}

@media (max-width:600px){
  #topBar{height:48px;padding:0 8px}
  #userName{display:none}
  #userAvatar{font-size:16px;width:26px;height:26px}
  .menu-toggle{width:34px;height:34px;font-size:18px}
  #app{padding-top:48px}
  #viewport{height:40vh;min-height:220px}
  #ui{max-height:calc(60vh - 50px);padding:8px 10px}
  h3{font-size:16px}
  summary{padding:10px 12px;font-size:13px}
  .section-body{padding:10px 12px}
  label{font-size:13px}
  input,select,button{font-size:13px;padding:9px 11px}
  input[type="number"]{direction:ltr;text-align:left}
  input[type="hidden"]{display:none !important}
  #metrics,#tests,#bom,#details,#constraints,#counts{font-size:12px;padding:8px}
  #bom table,#counts table{font-size:12px;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  #bom thead,#counts thead{display:block}
  #bom tbody,#counts tbody{display:block}
  #bom tr,#counts tr{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4px;margin-bottom:4px;padding:4px 0}
  #bom th,#counts th{display:none}
  #bom td,#counts td{border:none;padding:4px;text-align:right}
  #bom td:before,#counts td:before{content:attr(data-label) ": ";font-weight:600;color:var(--muted)}
  .actions button{padding:11px;font-size:13px}
}

@media print{
  body{overflow:visible}
  #topBar{display:none}
  #ui{position:static;width:auto;max-height:none;box-shadow:none}
  .actions{display:none}
}

.hidden{display:none !important}
.show{display:block !important}
.is-visible{visibility:visible}
.no-pad{padding:0}
.mt-6{margin-top:6px}
.mt-8{margin-top:8px}
.mt-28{margin-top:28px}
.mb-6{margin-bottom:6px}
.muted-small{font-size:12px}
.text-danger{color:#b91c1c}

.dim-label{background:rgba(17,24,39,.8);color:#fff;padding:2px 6px;border-radius:6px;font-size:11px;white-space:nowrap}
@media (max-width:900px){
  .dim-label{display:none !important}
}
.u-label{background:#ff7f11;color:#fff;padding:1px 4px;border-radius:4px;font-size:10px}

/* دکمه‌های شناور کنار پروژه */
.floating-btns{position:absolute;left:15px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:12px;z-index:100}
.float-btn{
  width:60px;
  height:60px;
  border-radius:16px;
  border:none;
  background:linear-gradient(135deg,#2563eb,#1e40af);
  color:#fff;
  font-size:20px;
  cursor:pointer;
  box-shadow:0 6px 20px rgba(37,99,235,0.4);
  transition:all 0.3s ease;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  padding:8px 6px;
  position:relative;
  overflow:hidden;
}
.float-btn::before{
  content:'';
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);
  transition:0.5s;
}
.float-btn:hover::before{left:100%}
.float-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(37,99,235,0.6)}
.float-btn:active{transform:translateY(-1px)}
.float-btn::after{
  content:attr(data-label);
  font-size:10px;
  font-weight:600;
  text-align:center;
  line-height:1.2;
  font-family:'Vazir','Noto Sans Arabic',system-ui,sans-serif;
}

/* استایل جداول داخل مودال */
.report-content table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:16px}
.report-content th{background:#f1f5f9;padding:10px 8px;text-align:right;font-weight:600;color:#374151;border-bottom:2px solid #e2e8f0}
.report-content td{padding:8px;text-align:right;border-bottom:1px solid #e2e8f0}
.report-content tbody tr:hover{background:#f8fafc}
.report-content tfoot td{background:#f1f5f9;font-weight:700}

/* عنوان بخش‌ها در پنل */
.panel-section-title{font-size:14px;font-weight:700;color:#1e3a5f;margin:16px 0 8px;padding-bottom:6px;border-bottom:2px solid #2563eb;display:flex;align-items:center;gap:8px}

/* پوشش تیره پشت پنل */
.panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:999;opacity:0;visibility:hidden;transition:all 0.3s}
.panel-overlay.show{opacity:1;visibility:visible}

/* دکمه‌های مخصوص هر بخش */
.float-btn.report-btn{background:linear-gradient(135deg,#059669,#047857)}
.float-btn.report-btn:hover{box-shadow:0 8px 25px rgba(5,150,105,0.6)}

.float-btn[id*="Bom"]{background:linear-gradient(135deg,#2563eb,#1e40af)}
.float-btn[id*="Pricing"]{background:linear-gradient(135deg,#f59e0b,#d97706)}
.float-btn[id*="Invoice"]{background:linear-gradient(135deg,#7c3aed,#5b21b6)}

/* مودال گزارش */
/* پاپ‌آپ‌های کشویی مدرن */
.report-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0);
  z-index:2000;
  display:flex;
  align-items:stretch;
  justify-content:flex-end;
  visibility:hidden;
  transition:background 0.3s ease, visibility 0s 0.3s;
}
.report-modal.open{
  visibility:visible;
  background:rgba(0,0,0,0.5);
  transition:background 0.3s ease, visibility 0s 0s;
}
.bom-header{background:linear-gradient(135deg,#059669,#10b981) !important}
.pricing-header{background:linear-gradient(135deg,#f59e0b,#fbbf24) !important}
.panel-section-title{font-weight:600;font-size:14px;margin:16px 0 10px;color:#374151;border-bottom:1px solid #e5e7eb;padding-bottom:6px}
#pricingModalContent .grid-two{display:grid;grid-template-columns:1fr 1fr;gap:10px}
#pricingModalContent label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#6b7280}
#pricingModalContent input{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;direction:ltr;text-align:left;font-family:'Vazirmatn',system-ui,sans-serif}
#pricingModalContent input:focus{border-color:#f59e0b;outline:none;box-shadow:0 0 0 3px rgba(245,158,11,0.2)}
#pricingModalContent .price-input{font-size:16px;font-weight:600;letter-spacing:0.5px;background:#fefce8}
.invoice-header{background:linear-gradient(135deg,#7c3aed,#a855f7) !important}
.report-container{
  background:#fff;
  width:100%;
  max-width:1100px;
  height:100%;
  display:flex;
  flex-direction:column;
  box-shadow:-10px 0 40px rgba(0,0,0,0.2);
  transform:translateX(100%);
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
  border-radius:20px 0 0 20px;
}
.report-modal.open .report-container{
  transform:translateX(0);
}
.report-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:linear-gradient(135deg,#059669,#047857);color:#fff;border-radius:0px 0 0 0}
.report-header h2{margin:0;font-size:20px}
.close-report-btn{line-height: 0;width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,0.2);color:#fff;font-size:20px;cursor:pointer;transition:all 0.2s}
.close-report-btn:hover{background:rgba(255,255,255,0.3);transform:rotate(90deg)}
.report-content{flex:1;overflow-y:auto;padding:24px}
.report-actions{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #e2e8f0;background:#f8fafc;border-radius:0}
.report-actions button{flex:1;padding:14px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all 0.2s}
.report-actions button:first-child{background:#2563eb;color:#fff}
.report-actions button:last-child{background:#059669;color:#fff}
.report-actions button:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.15)}

/* محتوای گزارش */
.report-section{margin-bottom:24px}
.report-section-title{font-size:16px;font-weight:700;color:#1e3a5f;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #059669;display:flex;align-items:center;gap:8px}
.report-image{width:100%;border-radius:12px;border:2px solid #e2e8f0;margin-bottom:16px}
.report-specs{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}
.spec-item{background:#4582be;padding:12px 16px;border-radius:10px;display:flex;justify-content:space-between;align-items:center}
.spec-label{color:#ffffff;font-size:13px}
.spec-value{font-weight:700;color:#ffffff;font-size:15px}
.report-table{width:100%;border-collapse:collapse;font-size:13px}
.report-table th{background:#f1f5f9;padding:12px 10px;text-align:right;font-weight:600;color:#374151}
.report-table td{padding:10px;text-align:right;border-bottom:1px solid #e2e8f0}
.report-table tfoot td{background:#059669;color:#fff;font-weight:700}
.report-footer{text-align:center;color:#94a3b8;font-size:12px;margin-top:20px;padding-top:16px;border-top:1px dashed #e2e8f0}

/* ریسپانسیو */
@media (max-width:768px){
  .floating-btns{
    position:fixed;
    bottom:0;
    left:0;
    right:0;
    top:auto;
    transform:none;
    flex-direction:row;
    justify-content:space-around;
    background:linear-gradient(135deg,#1e3a5f,#2563eb);
    padding:12px 8px 18px;
    gap:8px;
    border-radius:0;
    box-shadow:0 -4px 30px rgba(0,0,0,0.4);
    z-index:999;
    backdrop-filter:blur(10px);
  }
  .float-btn{
    width:70px;
    height:65px;
    font-size:20px;
    border-radius:16px;
    background:linear-gradient(135deg,#2563eb,#1e40af);
    border:2px solid rgba(255,255,255,0.1);
    flex-direction:column;
    gap:6px;
    box-shadow:0 4px 15px rgba(0,0,0,0.3);
    font-family:'Vazir','Noto Sans Arabic',system-ui,sans-serif;
    padding:8px 4px;
    position:relative;
    overflow:hidden;
  }
  .float-btn::before{
    content:'';
    position:absolute;
    top:0;
    left:-100%;
    width:100%;
    height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent);
    transition:0.4s;
  }
  .float-btn:active::before{left:100%}
  .float-btn::after{
    content:attr(data-label);
    font-size:9px;
    font-weight:600;
    color:#fff;
    text-shadow:0 1px 2px rgba(0,0,0,0.5);
    font-family:'Vazir','Noto Sans Arabic',system-ui,sans-serif;
  }
  .float-btn:hover,.float-btn:active{
    background:linear-gradient(135deg,#1d4ed8,#1e40af);
    transform:translateY(-2px);
    box-shadow:0 6px 20px rgba(0,0,0,0.4);
  }

  /* دکمه‌های مخصوص موبایل */
  .float-btn.report-btn{
    background:linear-gradient(135deg,#059669,#047857);
  }
  .float-btn[id*="Bom"]{
    background:linear-gradient(135deg,#2563eb,#1e40af);
  }
  .float-btn[id*="Pricing"]{
    background:linear-gradient(135deg,#f59e0b,#d97706);
  }
  .float-btn[id*="Invoice"]{
    background:linear-gradient(135deg,#7c3aed,#5b21b6);
  }
  #ui{padding-bottom:75px}
  .report-container{max-width:100%;border-radius:12px;max-height:85vh}
  .report-specs{grid-template-columns:1fr}
  #pricingModalContent .grid-two{grid-template-columns:1fr}
  .sticky-actions{display:none}
}

#invoice{margin-top:8px}

/* استایل فاکتور */
.invoice-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:linear-gradient(135deg,#1e3a5f,#2563eb);color:#fff;border-radius:10px 10px 0 0;margin-bottom:0}
.invoice-title{font-size:16px;font-weight:700}
.invoice-date{font-size:13px;opacity:0.9}
.invoice-customer,.invoice-desc{padding:8px 12px;background:#f8fafc;border-bottom:1px solid var(--line);font-size:13px}
.invoice-table{width:100%;border-collapse:collapse;font-size:12px;background:#fff;border:1px solid var(--line);border-top:none}
.invoice-table th{background:#f1f5f9;padding:10px 8px;text-align:right;font-weight:600;color:#374151;border-bottom:2px solid #e2e8f0}
.invoice-table td{padding:8px;text-align:right;border-bottom:1px solid #e2e8f0}
.invoice-table tbody tr:hover{background:#f8fafc}
.invoice-table tbody tr:nth-child(even){background:#fafafa}
.invoice-table tfoot td{background:#f1f5f9;font-weight:700;padding:12px 8px;border-top:2px solid #2563eb}

#tests.show{display:block}

/* ═══════════════════════════════════════════════════════ */
/* استایل چاپ گزارش سازه‌ای */
/* ═══════════════════════════════════════════════════════ */
@media print {
  * { 
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  
  body { 
    background: #fff !important; 
    margin: 0 !important;
    padding: 0 !important;
  }
  
  /* مخفی کردن همه چیز به جز گزارش */
  #viewport, 
  #topBar,
  .theme-btn, 
  .reset-btn,
  .header-row,
  details:not(:has(.structural-report)),
  details summary,
  .grid-two,
  .muted,
  #profileDiagram,
  #profileLipsRow,
  #soilRow,
  .section-body > label,
  .section-body > div:not(#structuralAnalysis) { 
    display: none !important; 
  }
  
  /* نمایش sidebar به صورت تمام صفحه */
  .sidebar {
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    overflow: visible !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
  }
  
  /* details باز باشد */
  details {
    display: block !important;
  }
  
  details[open] .section-body {
    display: block !important;
  }
  
  /* گزارش سازه‌ای */
  #structuralAnalysis {
    display: block !important;
  }
  
  .structural-report { 
    width: 100% !important; 
    max-width: 100% !important;
    border: none !important;
    box-shadow: none !important;
    padding: 15px !important;
    font-size: 11px !important;
    page-break-inside: auto;
  }
  
  .structural-report button { 
    display: none !important; 
  }
  
  /* جلوگیری از شکسته شدن بخش‌ها */
  .structural-report > div {
    page-break-inside: avoid;
    margin-bottom: 10px !important;
  }
  
  /* تنظیم صفحه */
  @page {
    size: A4;
    margin: 15mm;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* سیستم سفارش و پرداخت */
/* ═══════════════════════════════════════════════════════════════════════════ */

.order-section{margin-top:24px;padding-top:20px;border-top:2px dashed #e5e7eb}
.order-options{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.order-option{cursor:pointer}
.order-option input{display:none}
.option-card{
  padding:20px;
  border:2px solid #e5e7eb;
  border-radius:12px;
  text-align:center;
  transition:all 0.3s ease;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.order-option input:checked + .option-card{
  border-color:#2563eb;
  background:#eff6ff;
  box-shadow:0 4px 12px rgba(37,99,235,0.2);
}
.option-card.online-payment:hover{border-color:#059669}
.option-card.pending-payment:hover{border-color:#f59e0b}
.order-option input:checked + .option-card.online-payment{border-color:#059669;background:#ecfdf5}
.order-option input:checked + .option-card.pending-payment{border-color:#f59e0b;background:#fffbeb}
.option-icon{font-size:32px}
.option-title{font-weight:700;font-size:15px;color:#1e3a5f}
.option-desc{font-size:12px;color:#6b7280}

.submit-order-btn{background:linear-gradient(135deg,#059669,#047857) !important;font-size:16px !important}
.submit-order-btn:hover{box-shadow:0 6px 20px rgba(5,150,105,0.4) !important}

.order-message{margin-top:16px;padding:16px;border-radius:10px;text-align:center}
.success-message{background:#ecfdf5;color:#047857;border:1px solid #86efac;padding:16px;border-radius:10px}
.success-message strong{color:#059669}
.view-orders-link{
  background:linear-gradient(135deg,#1e3a5f,#2563eb);
  color:#fff;
  border:none;
  padding:10px 20px;
  border-radius:8px;
  cursor:pointer;
  font-weight:600;
  transition:transform 0.2s,box-shadow 0.2s;
}
.view-orders-link:hover{transform:scale(1.02);box-shadow:0 4px 15px rgba(37,99,235,0.3)}
.error-message{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:16px;border-radius:10px}

/* پنل سفارشات */
.orders-header{background:linear-gradient(135deg,#1e3a5f,#2563eb) !important}
.orders-container{max-width:1100px}
.admin-container{max-width:1100px}
.panel-settings-container{max-width:1100px}
.orders-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.stat-card{
  background:#f8fafc;
  padding:20px;
  border-radius:12px;
  text-align:center;
  border:1px solid #e5e7eb;
}
.stat-card.pending{background:#fffbeb;border-color:#fbbf24}
.stat-card.paid{background:#ecfdf5;border-color:#86efac}
.stat-card.revenue{background:#eff6ff;border-color:#93c5fd}
.stat-value{display:block;font-size:24px;font-weight:700;color:#1e3a5f}
.stat-label{font-size:12px;color:#6b7280;margin-top:4px}

.orders-filters{display:flex;gap:12px;margin-bottom:16px}
.orders-filters select{flex:1;max-width:200px}

.orders-table{width:100%;border-collapse:collapse;font-size:13px}
.orders-table th{background:#1e3a5f;color:#fff;padding:12px 8px;text-align:right}
.orders-table td{padding:10px 8px;border-bottom:1px solid #e5e7eb;vertical-align:middle}
.orders-table tbody tr:hover{background:#f8fafc}

.status-badge{
  display:inline-block;
  padding:4px 10px;
  border-radius:20px;
  font-size:11px;
  font-weight:600;
}
.status-badge.pending{background:#fef3c7;color:#92400e}
.status-badge.confirmed{background:#d1fae5;color:#065f46}
.status-badge.processing{background:#dbeafe;color:#1e40af}
.status-badge.shipped{background:#e0e7ff;color:#3730a3}
.status-badge.delivered{background:#d1fae5;color:#065f46}
.status-badge.cancelled{background:#fee2e2;color:#991b1b}

/* وضعیت‌های پرداخت */
.status-badge.paid{background:#d1fae5;color:#065f46}
.status-badge.card{background:#d1fae5;color:#065f46}
.status-badge.cash{background:#dbeafe;color:#1e40af}
.status-badge.failed{background:#fee2e2;color:#991b1b}
.status-badge.refunded{background:#e0e7ff;color:#3730a3}

.view-order-btn,.approve-order-btn,.reject-order-btn{
  width:auto;
  padding:6px 10px;
  border:none;
  border-radius:6px;
  cursor:pointer;
  font-size:14px;
  margin:0 2px;
}
.view-order-btn{background:#eff6ff}
.approve-order-btn{background:#d1fae5}
.reject-order-btn{background:#fee2e2}

/* جزئیات سفارش - طراحی کامل فاکتور */
.order-detail{padding:16px}
.order-detail.full-detail{padding:20px}

.invoice-header-print{
  text-align:center;
  margin-bottom:24px;
  padding-bottom:16px;
  border-bottom:3px double #1e3a5f;
}
.invoice-logo{font-size:22px;font-weight:Bold;color:#1e3a5f}
.invoice-title{font-size:16px;margin:8px 0;color:#374151}
.invoice-number{font-size:13px;color:#6b7280}

.order-header-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.order-header-info h3{margin:0;color:#1e3a5f;font-size:16px}

.detail-section{margin-bottom:16px;padding:16px;background:#f8fafc;border-radius:12px;border:1px solid #e5e7eb}
.detail-section h4{margin:0 0 14px;color:#1e3a5f;font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;padding-bottom:10px;border-bottom:1px solid #e5e7eb}
.detail-section p{margin:6px 0;font-size:13px}

/* گرید اطلاعات */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.info-item{display:flex;flex-direction:column;gap:4px;background:#fff;padding:10px 12px;border-radius:8px;border:1px solid #e5e7eb}
.info-label{font-size:11px;color:#6b7280}
.info-value{font-size:14px;font-weight:600;color:#1e3a5f}
.description-box{margin-top:12px;background:#fff;padding:12px;border-radius:8px;border:1px solid #e5e7eb}
.description-box p{margin:6px 0 0;font-size:13px;line-height:1.8}

/* مشخصات فنی */
.specs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.spec-box{background:linear-gradient(135deg,#1e3a5f,#2563eb);color:#fff;padding:12px;border-radius:10px;text-align:center}
.spec-label{display:block;font-size:11px;opacity:0.8;margin-bottom:4px}
.spec-value{display:block;font-size:16px;font-weight:Bold}
.no-specs{color:#6b7280;font-size:13px;text-align:center;padding:20px}

/* جدول فاکتور */
.invoice-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:10px;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}
.invoice-table th{background:linear-gradient(135deg,#1e3a5f,#2563eb);color:#fff;padding:12px 8px;font-weight:600;font-size:11px}
.invoice-table td{padding:10px 8px;border-bottom:1px solid #e5e7eb;background:#fff}
.invoice-table tr:last-child td{border-bottom:none}
.invoice-table tr:hover td{background:#f8fafc}
.invoice-table .center{text-align:center}
.invoice-table .price{text-align:left;direction:ltr;font-weight:500}
.invoice-table .total-cell{font-weight:700;color:#059669}

/* خلاصه مالی */
.financial-summary{background:linear-gradient(135deg,#f8fafc,#fff)}
.summary-box{background:#fff;padding:16px;border-radius:10px;border:1px solid #e5e7eb}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px dashed #e5e7eb;font-size:13px}
.summary-row:last-child{border-bottom:none}
.summary-row.discount .discount-value{color:#dc2626}
.summary-row.grand-total{margin-top:12px;padding-top:12px;border-top:2px solid #1e3a5f;border-bottom:none;font-size:16px}
.grand-total-value{font-size:18px;font-weight:Bold;color:#059669}

/* وضعیت پرداخت */
.payment-status-box{display:flex;align-items:center;gap:16px;padding:16px;border-radius:12px;background:#fff;border:2px solid #e5e7eb}
.payment-status-box.paid,.payment-status-box.card,.payment-status-box.cash{border-color:#059669;background:#ecfdf5}
.payment-status-box.pending{border-color:#f59e0b;background:#fefce8}
.payment-status-box.failed{border-color:#dc2626;background:#fef2f2}
.payment-icon{font-size:32px}
.payment-details{display:flex;flex-direction:column;gap:4px}
.payment-method{font-weight:600;color:#1e3a5f}
.payment-status-text{font-size:13px;color:#6b7280}
.payment-ref{font-size:12px;color:#2563eb;font-weight:500}

/* یادداشت مدیر */
.admin-notes-section textarea{width:100%;min-height:80px;padding:12px;border:1px solid #d1d5db;border-radius:10px;resize:vertical;font-size:13px}
.save-notes-btn{margin-top:10px;padding:10px 20px;background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600}
.save-notes-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(37,99,235,0.3)}

/* دکمه‌های عملیات */
.detail-actions{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid #e5e7eb;flex-wrap:wrap}
.detail-actions button{flex:1;min-width:120px;padding:12px 16px;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all 0.2s;font-size:13px}
.print-btn{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}
.pdf-btn{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff}
.tech-report-btn{background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff}
.print-btn:hover,.pdf-btn:hover,.tech-report-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}

/* بخش پروفیل‌ها و اتصالات */
.profiles-section,.connections-section{background:linear-gradient(135deg,#f0fdf4,#fff)}
.invoice-table.compact{font-size:11px}
.invoice-table.compact th,.invoice-table.compact td{padding:8px 6px}
.spec-box.highlight{background:linear-gradient(135deg,#059669,#047857)}

/* دفترچه محاسباتی */
.structural-section{background:linear-gradient(135deg,#faf5ff,#fff)}
.structural-content{
  background:#fff;
  padding:16px;
  border-radius:10px;
  border:1px solid #e5e7eb;
  max-height:400px;
  overflow-y:auto;
  font-size:12px;
  line-height:1.8;
}
div#managerCustomerSection {
  display: none !important;
}
button#resendOtpBtn {
  width: 98%;
  margin-left: 10px;
}
.structural-content table{width:100%;border-collapse:collapse;margin:10px 0}
.structural-content th,.structural-content td{border:1px solid #ddd;padding:6px 8px;font-size:11px}
.structural-content th{background:#f3f4f6}
.structural-content h3,.structural-content h4{margin:15px 0 10px;color:#1e3a5f}
.structural-content .pass{color:#059669;font-weight:Bold}
.structural-content .fail{color:#dc2626;font-weight:Bold}

/* جدول قدیمی */
.items-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:10px}
.items-table th{background:#e5e7eb;padding:8px}
.items-table td{padding:8px;border-bottom:1px solid #e5e7eb}
.items-table tfoot td{background:#1e3a5f;color:#fff;font-weight:700}

#adminNotesInput{width:100%;min-height:80px;padding:12px;border:1px solid #d1d5db;border-radius:8px;resize:vertical;font-family:inherit}
#saveAdminNotes{width:auto;margin-top:10px;padding:8px 16px;background:#2563eb;color:#fff;border:none;border-radius:8px}

.approve-btn{background:linear-gradient(135deg,#059669,#047857) !important}
.reject-btn{background:linear-gradient(135deg,#dc2626,#b91c1c) !important}

/* فرم ویرایش سفارش */
.order-edit-form{padding:10px}
.order-edit-form h3{margin:0 0 20px;color:#1e3a5f}
.edit-section{margin-bottom:20px;padding:16px;background:#f8fafc;border-radius:10px}
.edit-section h4{margin:0 0 12px;color:#374151;font-size:14px}
.edit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.edit-section label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#374151}
.edit-section input,.edit-section textarea{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:13px}
.edit-section input:focus,.edit-section textarea:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px rgba(37,99,235,0.1)}

.edit-item{display:grid;grid-template-columns:2fr 100px 100px 40px;gap:8px;margin-bottom:8px;align-items:center;padding:8px;background:#f9fafb;border-radius:8px}
.edit-item input{padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:12px}
.item-name-display{font-weight:500;color:#374151;font-size:13px}
.item-price-display{font-size:12px;color:#6b7280;text-align:left;direction:ltr}
.remove-item-btn{width:36px;height:36px;border:none;background:#fee2e2;color:#dc2626;border-radius:8px;cursor:pointer;font-size:14px}
.remove-item-btn:hover{background:#fecaca}
.add-item-btn{width:100%;padding:10px;margin-top:8px;border:2px dashed #d1d5db;background:transparent;color:#6b7280;border-radius:8px;cursor:pointer;font-size:13px;transition:all 0.2s}
.add-item-btn:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}

.edit-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}
.save-btn{padding:12px 24px;background:linear-gradient(135deg,#059669,#047857);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;font-size:14px}
.save-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(5,150,105,0.3)}
.cancel-btn{padding:12px 24px;background:#f3f4f6;color:#374151;border:none;border-radius:10px;font-weight:600;cursor:pointer;font-size:14px}
.cancel-btn:hover{background:#e5e7eb}

.actions-cell{white-space:nowrap}
.actions-cell button{margin:0 2px;padding:6px 8px;border:none;background:#f3f4f6;border-radius:6px; width: auto;cursor:pointer;transition:all 0.2s}
.actions-cell button:hover{background:#e5e7eb;transform:scale(1.1)}
.edit-order-btn{background:#fef3c7 !important;color:#d97706}
.edit-order-btn:hover{background:#fde68a !important}

/* کنترل وضعیت سفارش */
.status-controls{margin-top:20px;padding:20px;background:#f8fafc;border-radius:12px;border:1px solid #e5e7eb}
.status-section{margin-bottom:20px}
.status-section h4{margin:0 0 12px;color:#1e3a5f;font-size:14px;font-weight:600}
.status-section:last-child{margin-bottom:0}
.status-select{width:100%;padding:10px 12px;border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;margin-bottom:10px}
.status-select:focus{border-color:#2563eb;outline:none}
.update-status-btn{padding:10px 16px;background:linear-gradient(135deg,#059669,#047857);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:13px;margin-left:10px}
.update-status-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(5,150,105,0.3)}

/* فیلد جستجو */
.search-box{margin-bottom:16px;text-align:center}
.search-box input{width:100%;max-width:400px;padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-family:inherit;font-size:14px;direction:rtl;text-align:right}
.search-box input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px rgba(37,99,235,0.1)}

/* ریسپانسیو سفارشات */
@media (max-width:900px){
  .order-options{grid-template-columns:1fr}
  .orders-stats{grid-template-columns:repeat(2,1fr)}
  .orders-table{font-size:11px}
  .orders-table th,.orders-table td{padding:8px 4px}
}
@media (max-width:600px){
  .orders-stats{grid-template-columns:1fr}
  .stat-value{font-size:20px}
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* Toggle Slider Styles */
/* ═══════════════════════════════════════════════════════════════════════════ */

.toggle-slider {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  user-select: none;
  font-size: 13px;
  font-weight: 500;
  color: #374151;
  margin-top: 6px;
}

.toggle-slider input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: relative;
  width: 50px;
  height: 24px;
  background-color: #e5e7eb;
  border-radius: 24px;
  transition: background-color 0.3s ease;
}

.slider::before {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background-color: white;
  border-radius: 50%;
  transition: transform 0.3s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.toggle-slider input[type="checkbox"]:checked + .slider {
  background-color: #2563eb;
}

.toggle-slider input[type="checkbox"]:checked + .slider::before {
  transform: translateX(26px);
}

.red-toggle input[type="checkbox"]:checked + .slider {
  background-color: #dc2626;
}

.purple-toggle input[type="checkbox"]:checked + .slider {
  background-color: #7c3aed;
}

.slider:hover {
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.1);
}

.red-toggle .slider:hover {
  box-shadow: 0 0 0 2px rgba(220, 38, 38, 0.1);
}

.purple-toggle .slider:hover {
  box-shadow: 0 0 0 2px rgba(124, 58, 237, 0.1);
}

.label-text {
  flex: 1;
  text-align: right;
  direction: rtl;
}

/* Mobile responsive for toggle sliders */
@media (max-width: 900px) {
  .toggle-slider {
    gap: 10px;
  }

  .slider {
    width: 48px;
    height: 22px;
  }

  .slider::before {
    width: 18px;
    height: 18px;
  }

  .toggle-slider input[type="checkbox"]:checked + .slider::before {
    transform: translateX(26px);
  }

  .label-text {
    font-size: 14px;
  }
}

@media (max-width: 600px) {
  .toggle-slider {
    gap: 8px;
  }

  .slider {
    width: 44px;
    height: 20px;
  }

  .slider::before {
    width: 16px;
    height: 16px;
  }

  .toggle-slider input[type="checkbox"]:checked + .slider::before {
    transform: translateX(24px);
  }

  .label-text {
    font-size: 13px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════ */
/* Button Group Styles */
/* ═══════════════════════════════════════════════════════════════════════════ */

.button-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 6px;
}

.button-group label {
  font-size: 13px;
  font-weight: 500;
  color: #374151;
  margin: 0;
  direction: rtl;
  text-align: right;
}

.button-options {
  display: flex;
  gap: 8px;
  direction: rtl;
}

.option-btn {
  flex: 1;
  padding: 10px 12px;
  border: 2px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
  color: #6b7280;
  font-size: 13px;
  font-weight: 500;
  font-family: 'IRANyekan', 'Vazir', 'Tahoma', system-ui, sans-serif;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
  min-height: 44px;
  touch-action: manipulation;
}

.option-btn:hover {
  border-color: #d1d5db;
  background: #f9fafb;
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.option-btn.active {
  border-color: #2563eb;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.2);
}

.option-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* Mobile responsive for button groups */
@media (max-width: 900px) {
  .button-group {
    grid-column: 1 / -1; /* Span full width in grid */
  }

  .button-options {
    flex-direction: row; /* Keep buttons horizontal on tablets */
    gap: 6px;
  }

  .option-btn {
    padding: 12px 14px;
    font-size: 14px;
    min-height: 48px;
  }
}

@media (max-width: 600px) {
  .button-options {
    flex-direction: column; /* Stack buttons vertically on phones */
    gap: 8px;
  }

  .option-btn {
    padding: 11px 12px;
    font-size: 13px;
    min-height: 46px;
    width: 100%;
  }
}
