@font-face {
  font-family: 'DadyarVazir';
  src: url('/assets/fonts/Vazir.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
:root {
  --bg: #f8f5ef;
  --cream: #efe5d2;
  --surface: #ffffff;
  --surface-soft: #fffaf1;
  --ink: #132033;
  --ink-2: #2d3748;
  --muted: #667085;
  --navy: #0b1f3a;
  --navy-2: #102a4c;
  --gold: #b8872d;
  --gold-2: #d9b66f;
  --green: #0f766e;
  --danger: #b42318;
  --line: #e4d8c4;
  --shadow: 0 22px 55px rgba(12, 27, 49, 0.14);
  --soft-shadow: 0 12px 28px rgba(12, 27, 49, 0.08);
  font-family: 'DadyarVazir', 'Vazir', 'Vazirmatn', 'IranianSans', Tahoma, Arial, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--ink); line-height: 1.9; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(16px); background: rgba(248, 245, 239, .9); border-bottom: 1px solid rgba(184, 135, 45, .18); }
.site-header.compact { position: sticky; }
.nav { min-height: 82px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.brand { display: inline-flex; align-items: center; gap: 10px; color: var(--navy); font-size: 1.42rem; font-weight: 900; letter-spacing: -.03em; }
.brand img { width: 44px; height: 44px; object-fit: contain; border-radius: 12px; }
.nav-links { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; color: var(--ink-2); font-weight: 700; }
.nav-links a:not(.btn) { position: relative; }
.nav-links a:not(.btn)::after { content: ""; position: absolute; right: 0; bottom: -8px; width: 0; height: 2px; background: var(--gold); transition: .2s ease; }
.nav-links a:not(.btn):hover::after { width: 100%; }
.menu-toggle { display: none; border: 1px solid var(--line); background: #fff; border-radius: 12px; width: 42px; height: 42px; font-size: 1.4rem; cursor: pointer; }
.btn { border: 0; border-radius: 16px; padding: 11px 20px; cursor: pointer; font-weight: 900; display: inline-flex; align-items: center; justify-content: center; gap: 8px; transition: .18s ease; font: inherit; line-height: 1.5; }
.btn:hover { transform: translateY(-2px); box-shadow: var(--soft-shadow); }
.btn-primary { background: linear-gradient(135deg, var(--gold), #a36a18); color: #fff; box-shadow: 0 12px 28px rgba(184, 135, 45, .25); }
.btn-secondary { background: linear-gradient(135deg, var(--navy), var(--navy-2)); color: #fff; }
.btn-outline { background: rgba(255,255,255,.75); color: var(--navy); border: 1px solid var(--line); }
.btn.full { width: 100%; }
.hero-pro { position: relative; isolation: isolate; background: radial-gradient(circle at 20% 15%, rgba(217,182,111,.30), transparent 34%), linear-gradient(135deg, #fffaf1 0%, #f4ebdb 48%, #eef4f7 100%); overflow: hidden; }
.hero-pro::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(90deg, rgba(11,31,58,.04) 1px, transparent 1px), linear-gradient(rgba(11,31,58,.04) 1px, transparent 1px); background-size: 48px 48px; mask-image: linear-gradient(to bottom, #000, transparent 82%); z-index: -1; }
.hero-pro-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 48px; align-items: center; min-height: 700px; padding: 74px 0; }
.eyebrow { display: inline-flex; color: var(--gold); font-weight: 900; letter-spacing: -.02em; margin: 0 0 12px; }
h1, h2, h3 { color: var(--navy); line-height: 1.35; margin: 0; letter-spacing: -.035em; }
h1 { font-size: clamp(2.45rem, 5vw, 5rem); margin-bottom: 22px; }
h2 { font-size: clamp(1.8rem, 3vw, 3rem); }
h3 { font-size: 1.2rem; }
p { margin: 0; }
.lead { font-size: clamp(1.08rem, 1.7vw, 1.28rem); color: #475467; max-width: 760px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.trust-row { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 28px; }
.trust-row span { background: rgba(255,255,255,.72); border: 1px solid rgba(184,135,45,.22); color: var(--navy); padding: 8px 12px; border-radius: 999px; font-weight: 800; font-size: .92rem; }
.hero-visual { position: relative; min-height: 520px; border-radius: 34px; overflow: visible; }
.hero-visual > img { width: 100%; height: 520px; object-fit: cover; border-radius: 34px; box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.8); }
.hero-visual::after { content: ""; position: absolute; inset: 18px -18px -18px 18px; border: 1px solid rgba(184,135,45,.45); border-radius: 34px; z-index: -1; }
.floating-card { position: absolute; background: rgba(255,255,255,.92); backdrop-filter: blur(10px); box-shadow: var(--shadow); border: 1px solid rgba(184,135,45,.25); border-radius: 22px; padding: 14px 18px; display: grid; gap: 2px; min-width: 178px; }
.floating-card strong { color: var(--navy); font-size: 1.35rem; }
.floating-card span { color: var(--muted); font-size: .86rem; font-weight: 700; }
.top-card { top: 28px; right: -18px; }
.bottom-card { bottom: 34px; left: -18px; }
.section { padding: 84px 0; }
.cream { background: var(--cream); border-block: 1px solid var(--line); }
.section-title { max-width: 760px; margin-bottom: 34px; }
.section-title p:not(.eyebrow) { color: var(--muted); margin-top: 12px; }
.centered { text-align: center; margin-inline: auto; }
.about-grid { display: grid; grid-template-columns: 1fr .88fr; gap: 24px; align-items: start; }
.panel, .card, .service-card, .category-grid article, .portal-hero, .contact-card { background: var(--surface); border: 1px solid rgba(184,135,45,.20); border-radius: 28px; padding: 28px; box-shadow: var(--soft-shadow); }
.panel-large { padding: 34px; font-size: 1.06rem; color: #344054; }
.panel-large p + p { margin-top: 18px; }
.feature-stack { display: grid; gap: 14px; }
.feature-stack article { padding: 22px; background: var(--navy); color: #fff; border-radius: 24px; box-shadow: var(--soft-shadow); }
.feature-stack article:nth-child(2) { background: #173a62; }
.feature-stack article:nth-child(3) { background: #21476d; }
.feature-stack span { color: var(--gold-2); font-weight: 900; }
.feature-stack h3 { color: #fff; margin: 4px 0 8px; }
.feature-stack p { color: #dbe6ef; }
.grid { display: grid; gap: 20px; }
.cards-3 { grid-template-columns: repeat(3, 1fr); }
.cards-2 { grid-template-columns: repeat(2, 1fr); }
.service-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.service-card { min-height: 210px; position: relative; overflow: hidden; }
.service-card::after { content: ""; position: absolute; width: 120px; height: 120px; left: -55px; bottom: -55px; background: rgba(184,135,45,.12); border-radius: 50%; }
.service-card span { display: inline-flex; color: #936617; background: #fff4d6; border-radius: 999px; padding: 3px 10px; font-size: .8rem; font-weight: 900; margin-bottom: 12px; }
.service-card h3, .card h3 { margin-bottom: 10px; }
.service-card p, .card p, .category-grid p { color: var(--muted); }
.library-showcase { display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; gap: 28px; padding: 32px; background: #fff; border: 1px solid rgba(184,135,45,.18); border-radius: 34px; box-shadow: var(--soft-shadow); }
.library-showcase img { height: 360px; width: 100%; object-fit: cover; border-radius: 26px; }
.library-showcase p { color: #475467; margin-top: 16px; }
.category-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 18px; }
.category-grid article { padding: 22px; box-shadow: none; }
.dark-band { background: linear-gradient(135deg, var(--navy), #071529); color: #edf4ff; }
.dark-band h2, .dark-band p { color: #edf4ff; }
.gold { color: var(--gold-2); }
.judgments-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: center; }
.judgments-grid p { color: #cbd5e1; margin-top: 14px; }
.metric-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.metric-grid div { border: 1px solid rgba(217,182,111,.32); background: rgba(255,255,255,.06); border-radius: 24px; padding: 24px; }
.metric-grid strong { display: block; color: #fff; font-size: 1.35rem; }
.metric-grid span { color: #d8e2ef; }
.lawyers-section .card { min-height: 180px; }
.faq-grid { display: grid; grid-template-columns: .7fr 1.3fr; gap: 28px; }
.faq-list { display: grid; gap: 12px; }
details { background: #fff; border: 1px solid rgba(184,135,45,.20); border-radius: 20px; padding: 18px 22px; box-shadow: var(--soft-shadow); }
summary { cursor: pointer; font-weight: 900; color: var(--navy); }
details p { color: var(--muted); margin-top: 12px; }
.contact-card { display: flex; align-items: center; justify-content: space-between; gap: 24px; background: linear-gradient(135deg, #fff, #fff4da); }
.contact-card p { color: var(--muted); margin-top: 12px; }
.footer { background: #071529; color: #e8eef6; padding: 54px 0 26px; }
.footer-grid { display: grid; grid-template-columns: 1.3fr .8fr 1fr; gap: 28px; }
.footer strong { color: #fff; font-size: 1.1rem; }
.footer p { color: #b8c4d4; margin-top: 10px; }
.footer a { display: block; color: #f3ce7c; margin-top: 6px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: 32px; padding-top: 18px; color: #b8c4d4; text-align: center; font-size: .92rem; }
/* App */
.app-body { min-height: 100vh; background: radial-gradient(circle at top right, rgba(217,182,111,.24), transparent 30%), var(--bg); }
.app-shell { padding: 34px 0 72px; }
.portal-hero { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px; margin-bottom: 24px; background: linear-gradient(135deg, #fff, #fff4dc); }
.portal-hero img { width: 92px; height: 92px; object-fit: contain; }
.portal-hero p:not(.eyebrow) { color: var(--muted); max-width: 720px; margin-top: 10px; }
.auth-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; align-items: start; }
.auth-card h2 { margin-bottom: 6px; }
.subtle { color: var(--muted); }
label { display: block; font-weight: 900; color: #344054; margin: 14px 0; }
input, textarea, select { width: 100%; border: 1px solid var(--line); border-radius: 15px; padding: 12px 14px; font: inherit; background: #fffdf8; color: var(--ink); outline: none; transition: .16s ease; }
input:focus, textarea:focus, select:focus { border-color: var(--gold); box-shadow: 0 0 0 4px rgba(184,135,45,.13); }
textarea { resize: vertical; }
.form-status { min-height: 28px; color: var(--green); font-weight: 900; margin-top: 8px; }
.form-status.error { color: var(--danger); }
.hidden { display: none !important; }
.dashboard-area { display: grid; gap: 20px; }
.dashboard-head { display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.panel-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 14px; }
.list { display: grid; gap: 12px; margin-top: 18px; }
.item { border: 1px solid var(--line); border-radius: 20px; padding: 16px; background: #fffdf8; }
.item strong { color: var(--navy); }
.item small { display: block; color: var(--muted); margin-top: 4px; }
.item p { color: #475467; margin-top: 8px; }
.item-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.search-row { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; margin-top: 18px; }
.badge { display: inline-flex; padding: 4px 10px; border-radius: 999px; background: #e6f4ff; color: #075985; font-size: .78rem; font-weight: 900; }
.library-results .item { border-right: 4px solid var(--gold); }
.messages { margin-top: 12px; padding-right: 10px; border-right: 2px solid rgba(184,135,45,.25); }
@media (max-width: 1050px) {
  .service-grid, .category-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-pro-grid, .about-grid, .library-showcase, .judgments-grid, .faq-grid { grid-template-columns: 1fr; }
  .hero-visual { min-height: auto; }
  .hero-visual > img { height: 420px; }
}
@media (max-width: 820px) {
  .nav { min-height: 68px; }
  .menu-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .nav-links { display: none; position: absolute; top: 68px; right: 16px; left: 16px; background: #fff; border: 1px solid var(--line); border-radius: 22px; padding: 16px; box-shadow: var(--shadow); }
  .nav-links.open { display: grid; }
  .hero-pro-grid { padding: 42px 0; }
  .hero-visual > img { height: 320px; }
  .floating-card { position: static; margin-top: 10px; }
  .section { padding: 56px 0; }
  .service-grid, .category-grid, .cards-3, .cards-2, .auth-grid, .footer-grid, .metric-grid { grid-template-columns: 1fr; }
  .contact-card, .dashboard-head, .panel-head { align-items: stretch; flex-direction: column; }
  .search-row { grid-template-columns: 1fr; }
  .portal-hero { grid-template-columns: 1fr; }
}
.pulse-focus { animation: pulseFocus 1.5s ease; }
@keyframes pulseFocus { 0%, 100% { box-shadow: var(--soft-shadow); } 45% { box-shadow: 0 0 0 5px rgba(184,135,45,.20), var(--shadow); } }


/* Dadyar v2: dynamic organizational registration */
.auth-workspace { display: grid; grid-template-columns: .82fr 1.18fr; gap: 22px; align-items: start; }
.auth-aside { position: sticky; top: 104px; background: linear-gradient(145deg, #ffffff, #fff4dc); overflow: hidden; }
.auth-aside::after { content: ""; position: absolute; width: 210px; height: 210px; left: -90px; bottom: -90px; background: rgba(184,135,45,.12); border-radius: 50%; }
.auth-tabs { display: grid; gap: 10px; margin: 24px 0; position: relative; z-index: 1; }
.auth-tab { width: 100%; border: 1px solid rgba(184,135,45,.22); background: rgba(255,255,255,.78); border-radius: 18px; padding: 13px 16px; text-align: right; cursor: pointer; color: var(--navy); font: inherit; font-weight: 900; transition: .18s ease; }
.auth-tab:hover { transform: translateY(-1px); box-shadow: var(--soft-shadow); }
.auth-tab.active { background: linear-gradient(135deg, var(--navy), var(--navy-2)); color: #fff; border-color: transparent; }
.auth-notes { display: grid; gap: 12px; position: relative; z-index: 1; }
.note-card { border: 1px solid rgba(184,135,45,.18); border-radius: 18px; padding: 14px; background: rgba(255,255,255,.72); }
.note-card strong { display: block; color: var(--navy); margin-bottom: 4px; }
.note-card span { color: var(--muted); font-size: .92rem; }
.auth-stage { min-height: 650px; }
.auth-form { display: none; animation: fadeSlide .24s ease; }
.auth-form.active { display: block; }
.form-title-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 16px; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 16px; }
.form-grid.single { grid-template-columns: 1fr; max-width: 540px; }
.span-2 { grid-column: 1 / -1; }
.step-indicator { display: flex; flex-wrap: wrap; gap: 8px; margin: 18px 0 8px; }
.step-indicator span { border: 1px solid var(--line); background: #fffdf8; color: var(--muted); border-radius: 999px; padding: 6px 12px; font-weight: 900; font-size: .84rem; }
.step-indicator span.active { border-color: rgba(184,135,45,.35); color: #8a5b13; background: #fff4d6; }
.check-row { display: flex; align-items: flex-start; gap: 10px; margin: 16px 0; color: #475467; font-weight: 800; }
.check-row input { width: 18px; min-width: 18px; margin-top: 7px; accent-color: var(--gold); }
.file-field { border: 1px dashed rgba(184,135,45,.52); border-radius: 20px; background: #fffaf1; padding: 14px; }
.file-field input { margin-top: 8px; background: #fff; }
.file-field small { display: block; margin-top: 7px; color: var(--muted); font-weight: 700; }
.form-status.success { color: var(--green); }
.error-text { color: var(--danger) !important; }
.is-loading { opacity: .72; }
.is-loading::after { content: ""; display: none; }
.refined-portal { grid-template-columns: minmax(0, 1fr) 330px; }
.portal-hero-card { border: 1px solid rgba(184,135,45,.25); background: rgba(255,255,255,.72); border-radius: 24px; padding: 22px; box-shadow: var(--soft-shadow); }
.portal-hero-card strong { color: var(--navy); display: block; margin-bottom: 10px; font-size: 1.08rem; }
.portal-hero-card ol { margin: 0; padding-right: 20px; color: #475467; font-weight: 800; }
.hero-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.hero-badges span { background: rgba(255,255,255,.7); border: 1px solid rgba(184,135,45,.22); border-radius: 999px; padding: 5px 10px; color: var(--navy); font-weight: 900; font-size: .86rem; }
.identity-panel { border-right: 5px solid var(--gold); }
.identity-form.hidden { display: none; }
.disabled-panel { opacity: .62; position: relative; }
.disabled-panel::before { content: "تکمیل مدارک هویتی لازم است"; position: absolute; left: 18px; top: 18px; z-index: 2; background: #fff4d6; color: #8a5b13; border: 1px solid rgba(184,135,45,.28); border-radius: 999px; padding: 5px 10px; font-size: .78rem; font-weight: 900; }
.admin-user-item { border-right: 4px solid var(--navy); }
input[type="file"] { padding: 10px; cursor: pointer; }
@keyframes fadeSlide { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
@media (max-width: 980px) {
  .auth-workspace, .refined-portal { grid-template-columns: 1fr; }
  .auth-aside { position: static; }
  .auth-stage { min-height: auto; }
}
@media (max-width: 680px) {
  .form-grid { grid-template-columns: 1fr; }
  .span-2 { grid-column: auto; }
  .form-title-row { flex-direction: column; }
}


.password-wrap { position: relative; display: flex; align-items: stretch; gap: 8px; }
.password-wrap input { flex: 1; padding-left: 86px; }
.password-toggle { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); border: 0; background: transparent; color: var(--gold-dark); font-weight: 900; cursor: pointer; padding: 6px 8px; }
.password-toggle:hover { color: var(--ink); }
.error-text { color: #b91c1c; }

/* v2.2 admin and library-management refinements */
.admin-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;margin-top:18px}.admin-card{border:1px solid rgba(121,91,43,.18);background:rgba(255,255,255,.72);border-radius:22px;padding:18px;box-shadow:0 18px 50px rgba(28,32,46,.06)}.admin-card h3{margin:0 0 10px}.compact-form{display:grid;gap:12px}.compact-form label{font-weight:700;color:var(--text)}.compact-form input,.compact-form textarea,.compact-form select{width:100%;margin-top:7px}.library-admin-card{margin-top:18px}.library-admin-form{margin-bottom:16px}.library-admin-item .item-actions{justify-content:flex-start}.btn.danger,.danger{border-color:rgba(165,42,42,.35)!important;color:#9f2f2f!important}.btn.danger:hover{background:#fff0f0!important}.error-text{color:#a31e1e}@media(max-width:900px){.admin-grid{grid-template-columns:1fr}.admin-card{padding:14px}}


/* v2.4 integrated login and public library refinements */
input[type="email"],
input[type="password"],
input[type="text"].ltr-input,
.ltr-input,
.ltr-wrap input {
  direction: ltr !important;
  text-align: left !important;
  unicode-bidi: plaintext;
  font-family: Arial, Tahoma, sans-serif;
}
.form-status:empty { display: none; }
.form-status.error { display: block; color: var(--danger); }
.form-status.success { display: block; color: #0f766e; }

.library-body { background: var(--bg); }
.library-page { padding: 46px 0 70px; }
.library-hero { display: grid; grid-template-columns: minmax(0,1.5fr) minmax(260px,.6fr); gap: 28px; align-items: center; margin-bottom: 22px; }
.library-hero h1 { margin: 8px 0 12px; color: var(--navy); font-size: clamp(2rem, 4vw, 3.5rem); }
.library-hero p { color: var(--muted); line-height: 2; }
.library-hero-badges { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }
.library-hero-badges span, .library-chip {
  border: 1px solid var(--line); background: var(--surface-soft); color: var(--navy); border-radius: 999px; padding: 8px 12px; font-weight: 800;
}
.library-search-panel { margin-bottom: 20px; }
.library-search-actions { display:flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.library-layout { display: grid; grid-template-columns: 360px minmax(0,1fr); gap: 20px; align-items: start; }
.panel-head { display:flex; justify-content:space-between; gap: 10px; align-items:center; margin-bottom: 14px; }
.panel-head h2 { margin:0; color: var(--navy); }
.document-list, .library-full-results { display:grid; gap: 10px; }
.doc-pill {
  width:100%; text-align:right; cursor:pointer; border:1px solid var(--line); background: var(--surface); color: var(--ink);
  border-radius: 16px; padding: 12px; display:grid; gap: 6px; transition: .2s ease;
}
.doc-pill:hover { transform: translateY(-1px); border-color: rgba(184,135,45,.65); box-shadow: var(--shadow-soft); }
.doc-pill strong { color: var(--navy); }
.doc-pill small, .article-result small { color: var(--muted); }
.article-result { border:1px solid var(--line); border-radius: 18px; padding: 16px; background: var(--surface); display:grid; gap: 8px; }
.article-result strong { color: var(--navy); }
.article-result p { margin: 0; line-height: 2; color: var(--ink-2); }
.article-viewer { margin-top: 20px; }
.article-content { white-space: normal; line-height: 2.15; color: var(--ink); font-size: 1.02rem; }
.error-text { color: var(--danger); }
.library-admin-panel { margin-top: 24px; border: 1px solid rgba(184,135,45,.35); }
.library-admin-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items:start; }
.admin-hidden { display:none !important; }
@media (max-width: 900px) {
  .library-hero, .library-layout, .library-admin-grid { grid-template-columns: 1fr; }
  .library-hero-badges { justify-content: flex-start; }
}
@media (max-width: 760px) {
  .nav-links.open { display: flex; }
}

/* v2.5 workspace dashboard upgrade */
.workspace-area { display: grid; gap: 20px; }
.workspace-top { display: flex; align-items: center; justify-content: space-between; gap: 18px; background: linear-gradient(135deg, #fff, #fff7e7); }
.workspace-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.workspace-grid { display: grid; grid-template-columns: 300px 230px minmax(0,1fr); gap: 18px; align-items: start; direction: rtl; }
.workspace-sidebar { position: sticky; top: 92px; background: linear-gradient(145deg, #fff, #fff8ea); }
.profile-card-mini { display: flex; align-items: center; gap: 12px; padding-bottom: 14px; border-bottom: 1px solid var(--line); margin-bottom: 14px; }
.profile-card-mini strong { display: block; color: var(--navy); }
.profile-card-mini span { display: block; margin-top: 4px; }
.profile-photo-wrap { position: relative; width: 74px; height: 74px; border-radius: 22px; overflow: hidden; background: linear-gradient(135deg, var(--navy), var(--gold)); display: grid; place-items: center; color: #fff; font-weight: 950; font-size: 1.2rem; box-shadow: var(--soft-shadow); }
.profile-photo-wrap img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.profile-photo-wrap img.hidden { display: none; }
.profile-facts { display: grid; gap: 10px; margin: 0 0 16px; }
.profile-facts div { border: 1px solid rgba(184,135,45,.16); background: rgba(255,255,255,.72); border-radius: 16px; padding: 10px; }
.profile-facts dt { font-size: .78rem; color: var(--muted); font-weight: 900; }
.profile-facts dd { margin: 4px 0 0; color: var(--ink); font-weight: 900; overflow-wrap: anywhere; }
.national-card-preview { border: 1px dashed rgba(184,135,45,.4); border-radius: 18px; padding: 10px; background: #fffaf1; margin: 12px 0; }
.national-card-preview span { display: block; color: var(--muted); font-weight: 900; margin-bottom: 8px; }
.national-card-preview img { width: 100%; max-height: 170px; object-fit: contain; border-radius: 12px; background: #fff; }
.mini-form { border-top: 1px solid var(--line); padding-top: 12px; margin-top: 12px; }
.mini-form h3 { margin: 0 0 8px; color: var(--navy); }
.mini-form label { margin: 9px 0; font-size: .92rem; }
.workspace-menu { position: sticky; top: 92px; display: grid; gap: 9px; padding: 14px; }
.workspace-tab { width: 100%; border: 1px solid rgba(184,135,45,.22); background: rgba(255,255,255,.82); color: var(--navy); border-radius: 16px; padding: 12px 13px; text-align: right; cursor: pointer; font: inherit; font-weight: 950; transition: .18s ease; }
.workspace-tab:hover { transform: translateY(-1px); box-shadow: var(--soft-shadow); }
.workspace-tab.active { background: linear-gradient(135deg, var(--navy), var(--navy-2)); color: #fff; border-color: transparent; }
.workspace-main { min-width: 0; display: block; }
.workspace-panel { display: none; animation: fadeSlide .22s ease; }
.workspace-panel.active { display: block; }
.case-item { border-right: 5px solid rgba(184,135,45,.6); }
.case-item-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.message-row { border: 1px solid rgba(184,135,45,.16); background: #fffdf8; border-radius: 16px; padding: 12px; margin-top: 8px; }
.message-row strong { color: var(--navy); }
.message-row small { color: var(--muted); display: block; margin: 4px 0; }
.admin-case-form, .admin-user-settings { margin-top: 14px; border-top: 1px dashed rgba(184,135,45,.28); padding-top: 12px; }
.admin-case-form .form-grid, .admin-user-settings .form-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.admin-stats { display: grid; grid-template-columns: repeat(5, minmax(0,1fr)); gap: 10px; margin: 14px 0 18px; }
.stat-pill { border: 1px solid rgba(184,135,45,.2); border-radius: 18px; background: #fffaf1; padding: 14px; text-align: center; }
.stat-pill strong { display: block; color: var(--navy); font-size: 1.55rem; }
.stat-pill span { color: var(--muted); font-weight: 900; font-size: .85rem; }
.full { width: 100%; justify-content: center; }
@media (max-width: 1180px) { .workspace-grid { grid-template-columns: 260px minmax(190px,220px) minmax(0,1fr); } .admin-stats { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 980px) { .workspace-grid { grid-template-columns: 1fr; } .workspace-sidebar, .workspace-menu { position: static; } .workspace-menu { grid-template-columns: repeat(2,1fr); } .workspace-top { flex-direction: column; align-items: stretch; } }
@media (max-width: 680px) { .workspace-menu { grid-template-columns: 1fr; } .admin-case-form .form-grid, .admin-user-settings .form-grid { grid-template-columns: 1fr; } .admin-stats { grid-template-columns: 1fr 1fr; } .case-item-head { flex-direction: column; } }

/* v2.6 quality and workspace refinement */
@font-face {
  font-family: 'DadyarText';
  src: local('Vazir'), local('Vazirmatn'),
       url('/assets/fonts/Vazir.woff2') format('woff2'),
       url('/assets/fonts/Vazir.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'DadyarTitle';
  src: local('Iranian Sans'), local('IranianSans'),
       url('/assets/fonts/IranianSans.woff2') format('woff2'),
       url('/assets/fonts/Iranian Sans(1).ttf') format('truetype');
  font-weight: 400 900;
  font-style: normal;
  font-display: swap;
}
:root { font-family: 'DadyarText', 'Vazir', 'IranianSans', Tahoma, Arial, sans-serif; }
body { font-size: 15.8px; }
h1, h2, h3, .brand, .btn, .workspace-tab { font-family: 'DadyarTitle', 'DadyarText', Tahoma, Arial, sans-serif; }
h1 { font-size: clamp(2.35rem, 4.35vw, 4.25rem); letter-spacing: -.045em; }
h2 { font-size: clamp(1.55rem, 2.35vw, 2.35rem); }
h3 { font-size: 1.08rem; }
.lead { font-size: clamp(1.03rem, 1.35vw, 1.18rem); line-height: 2.08; }
.nav { min-height: 74px; }
.nav-links { font-size: .94rem; gap: 14px; }
.brand { font-size: 1.28rem; }
.brand img { width: 40px; height: 40px; }
.hero-pro-grid { min-height: 640px; padding: 62px 0; }
.hero-copy .eyebrow { font-size: 1rem; }
.trust-row span { font-size: .88rem; }

.workspace-fixed { gap: 14px; }
.workspace-menu-horizontal {
  position: sticky;
  top: 82px;
  z-index: 20;
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  overflow-x: auto;
  padding: 12px;
  border-radius: 24px;
  background: linear-gradient(135deg, #102a4c, #0b1f3a 62%, #153d65);
  box-shadow: 0 16px 42px rgba(11,31,58,.14);
}
.workspace-menu-horizontal .workspace-tab {
  width: auto;
  min-width: max-content;
  white-space: nowrap;
  text-align: center;
  border-radius: 14px;
  padding: 10px 13px;
  font-size: .86rem;
  font-weight: 850;
  color: #edf4ff;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.15);
}
.workspace-menu-horizontal .workspace-tab:hover { transform: none; background: rgba(255,255,255,.16); }
.workspace-menu-horizontal .workspace-tab.active {
  background: linear-gradient(135deg, #d9b66f, #b8872d);
  color: #071529;
  box-shadow: 0 8px 22px rgba(184,135,45,.2);
}
.workspace-grid-v26 {
  display: grid;
  grid-template-columns: 292px minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
  min-height: 650px;
}
.workspace-sidebar {
  top: 148px;
  max-height: 650px;
  overflow: auto;
  padding: 20px;
}
.workspace-main {
  min-height: 650px;
  max-height: 650px;
  overflow: auto;
  border-radius: 28px;
}
.workspace-main > .panel,
.workspace-main > .workspace-panel > .panel,
.workspace-main > .workspace-panel > form.panel {
  min-height: 650px;
}
.profile-card-mini { gap: 10px; padding-bottom: 12px; margin-bottom: 12px; }
.profile-card-mini strong { font-size: .98rem; }
.profile-card-mini span { font-size: .82rem; }
.profile-photo-wrap { width: 64px; height: 64px; border-radius: 18px; }
.profile-facts { gap: 8px; margin-bottom: 12px; }
.profile-facts div { padding: 8px 10px; border-radius: 14px; }
.profile-facts dt { font-size: .73rem; }
.profile-facts dd { font-size: .84rem; font-weight: 850; }
.profile-action-buttons { display: grid; gap: 8px; border-top: 1px solid var(--line); padding-top: 12px; margin-top: 12px; }
.profile-action-buttons .btn { padding: 9px 11px; border-radius: 14px; font-size: .86rem; }
.workspace-user-line { margin-top: 10px; font-size: .82rem; line-height: 1.8; }
.workspace-action-panel .workspace-form { margin-top: 12px; }
.workspace-statusbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 10px 16px;
  border-radius: 18px;
  background: linear-gradient(135deg, #fffdf8, #f5ebd8);
  color: #344054;
  font-size: .86rem;
  font-weight: 850;
}
.workspace-statusbar strong { color: var(--navy); }
.panel-head h2 { font-size: clamp(1.25rem, 1.6vw, 1.7rem); }
.panel-head .subtle { font-size: .9rem; line-height: 1.9; }
.admin-card h3 { font-size: 1rem; }

@media (max-width: 1180px) {
  .workspace-grid-v26 { grid-template-columns: 260px minmax(0,1fr); }
  .workspace-menu-horizontal { top: 74px; }
}
@media (max-width: 980px) {
  .workspace-menu-horizontal { position: static; flex-wrap: wrap; }
  .workspace-menu-horizontal .workspace-tab { flex: 1 1 180px; }
  .workspace-grid-v26 { grid-template-columns: 1fr; min-height: auto; }
  .workspace-sidebar, .workspace-main { position: static; max-height: none; min-height: auto; }
  .workspace-main > .panel,
  .workspace-main > .workspace-panel > .panel,
  .workspace-main > .workspace-panel > form.panel { min-height: auto; }
  .profile-action-buttons { grid-template-columns: repeat(2, minmax(0,1fr)); }
  #refreshBtn { grid-column: 1 / -1; }
}
@media (max-width: 680px) {
  body { font-size: 15px; }
  .profile-action-buttons { grid-template-columns: 1fr; }
  .workspace-statusbar { display: grid; align-items: start; }
  .workspace-menu-horizontal .workspace-tab { flex-basis: 100%; }
  h1 { font-size: clamp(2rem, 10vw, 3.1rem); }
}


/* v2.7 homepage typography, nav alignment and legal resources workspace */
@font-face {
  font-family: 'DadyarIranSans';
  src: local('Iranian Sans'), local('IranianSans'),
       url('/assets/fonts/IranianSans.woff2') format('woff2'),
       url('/assets/fonts/Iranian Sans(1).ttf') format('truetype');
  font-weight: 300 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'DadyarVazir';
  src: local('Vazir'), local('Vazirmatn'),
       url('/assets/fonts/Vazir.woff2') format('woff2'),
       url('/assets/fonts/Vazir.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
:root { font-family: 'DadyarIranSans', 'DadyarVazir', 'Vazir', Tahoma, Arial, sans-serif; }
body, input, textarea, select, button { font-family: 'DadyarIranSans', 'DadyarVazir', Tahoma, Arial, sans-serif; }
p, li, .subtle, .lead, details p, .service-card p, .card p { font-family: 'DadyarVazir', 'DadyarIranSans', Tahoma, Arial, sans-serif; }
h1, h2, h3, .brand, .eyebrow, .nav-links, .btn { font-family: 'DadyarIranSans', 'DadyarVazir', Tahoma, Arial, sans-serif; }
.site-header .nav { justify-content: flex-start; direction: rtl; }
.site-header .brand { flex: 0 0 auto; }
.site-header .nav-links { margin-inline-start: 22px; margin-inline-end: 0; justify-content: flex-start; }
.site-header .menu-toggle { margin-inline-start: auto; }
.hero-visual { overflow: hidden; }
.hero-visual::after { inset: 18px; border-radius: 34px; }
.hero-visual > img { filter: saturate(1.02) contrast(1.02); }
.contracts-hero { display: grid; grid-template-columns: 1.25fr .75fr; gap: 22px; align-items: center; background: linear-gradient(135deg, #fff, #fff4dc); margin-bottom: 18px; }
.legal-workspace { display: grid; grid-template-columns: 270px minmax(0,1fr); gap: 18px; align-items: stretch; direction: rtl; }
.legal-workspace-side { position: sticky; top: 92px; align-self: start; display: grid; gap: 10px; background: linear-gradient(145deg, #fff, #fff8ea); }
.legal-workspace-side h2 { font-size: 1.35rem; margin-bottom: 8px; }
.legal-note { border-top: 1px solid var(--line); margin-top: 12px; padding-top: 14px; color: var(--muted); }
.legal-note strong { display: block; color: var(--navy); margin-bottom: 6px; }
.legal-workspace-main { min-height: 640px; border-radius: 28px; overflow: hidden; }
.legal-panel { display: none; }
.legal-panel.active { display: block; animation: fadeSlide .22s ease; }
.legal-panel > .panel { min-height: 640px; }
.legal-list { display: grid; gap: 12px; margin-top: 18px; }
.legal-item { display: flex; align-items: center; justify-content: space-between; gap: 16px; border: 1px solid rgba(184,135,45,.18); background: #fffdf8; border-radius: 20px; padding: 16px; }
.legal-item h3 { margin: 8px 0 6px; font-size: 1.04rem; }
.legal-item p { color: var(--muted); }
.legal-item small { display: block; margin-top: 8px; color: #667085; font-weight: 800; }
.legal-viewer { margin-top: 18px; border: 1px solid rgba(184,135,45,.20); border-radius: 22px; padding: 18px; background: #fffaf1; }
.legal-viewer pre { white-space: pre-wrap; line-height: 2; font-family: 'DadyarVazir', Tahoma, Arial, sans-serif; color: #26364d; background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 16px; max-height: 420px; overflow: auto; }
.footer-grid div:last-child a { line-height: 1.8; }
@media (max-width: 980px) {
  .site-header .nav { justify-content: space-between; }
  .site-header .nav-links { margin-inline-start: 0; }
  .contracts-hero, .legal-workspace { grid-template-columns: 1fr; }
  .legal-workspace-side { position: static; }
  .legal-item { align-items: stretch; flex-direction: column; }
}


/* v2.7.4 workspace hero removal and official library visual refinements */
.app-body.signed-in .portal-hero,
.app-body.signed-in #portalHero {
  display: none !important;
}
.workspace-site-links {
  margin-top: -10px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 10px 14px;
  border-radius: 0 0 20px 20px;
  background: linear-gradient(135deg, #0f4c81, #173b67 58%, #0f2f56);
  border: 1px solid rgba(15,76,129,.28);
  box-shadow: 0 16px 38px rgba(15, 76, 129, .18);
}
.workspace-site-links a {
  color: #ffffff;
  text-decoration: none;
  font-weight: 900;
  font-size: .9rem;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
}
.workspace-site-links a:hover {
  background: rgba(255,255,255,.22);
  transform: translateY(-1px);
}
.library-body {
  background:
    radial-gradient(circle at 8% 4%, rgba(15,76,129,.13), transparent 30%),
    radial-gradient(circle at 92% 12%, rgba(184,135,45,.12), transparent 34%),
    linear-gradient(180deg, #f5f8fc 0%, #fffaf1 100%);
}
.library-page { padding-top: 34px; }
.library-hero {
  position: relative;
  overflow: hidden;
  color: #fff;
  border: 0;
  background:
    linear-gradient(135deg, rgba(15,47,86,.96), rgba(15,76,129,.92) 58%, rgba(35,92,139,.90)),
    url('/assets/images/law-court.jpg') center/cover no-repeat;
  box-shadow: 0 30px 80px rgba(15,47,86,.22);
}
.library-hero::after {
  content: '';
  position: absolute;
  inset: auto -80px -120px auto;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: rgba(184,135,45,.28);
  filter: blur(2px);
}
.library-hero > * { position: relative; z-index: 1; }
.library-hero .eyebrow { color: #f3d38d; }
.library-hero h1 { color: #fff; text-shadow: 0 10px 25px rgba(0,0,0,.18); }
.library-hero p { color: rgba(255,255,255,.88); }
.library-hero-badges span,
.library-chip {
  color: #fff;
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.22);
  backdrop-filter: blur(10px);
}
.library-search-panel {
  border-color: rgba(15,76,129,.16);
  background: linear-gradient(135deg, #ffffff, #f6faff);
  box-shadow: 0 22px 58px rgba(15,76,129,.10);
}
.library-search-panel input,
.library-search-panel select {
  border-color: rgba(15,76,129,.20);
  background: #fff;
}
.library-search-panel input:focus,
.library-search-panel select:focus {
  border-color: rgba(15,76,129,.55);
  box-shadow: 0 0 0 4px rgba(15,76,129,.10);
}
.library-search-actions .btn-primary {
  background: linear-gradient(135deg, #0f4c81, #173b67);
  box-shadow: 0 18px 36px rgba(15,76,129,.20);
}
.library-docs-box,
.library-results-box,
.article-viewer {
  border-color: rgba(15,76,129,.14);
  box-shadow: 0 18px 45px rgba(15,76,129,.08);
}
.library-docs-box {
  background: linear-gradient(180deg, #ffffff, #f4f8fd);
}
.library-results-box {
  background: linear-gradient(180deg, #ffffff, #fffaf2);
}
.library-results .item,
.library-full-results .item,
.document-list .doc-pill {
  border-color: rgba(15,76,129,.12);
}
.document-list .doc-pill {
  background: linear-gradient(135deg, #ffffff, #f5f9ff);
  border-right: 4px solid #0f4c81;
}
.document-list .doc-pill:hover {
  background: #eef6ff;
  transform: translateY(-1px);
}
.article-result {
  border-right: 4px solid #b8872d !important;
  background: linear-gradient(135deg, #ffffff, #fffaf1);
}
.article-viewer {
  background: linear-gradient(135deg, #ffffff, #f5f9ff);
}
@media (max-width: 680px) {
  .workspace-site-links { border-radius: 16px; margin-top: 0; justify-content: stretch; }
  .workspace-site-links a { flex: 1 1 100%; text-align: center; }
}

/* v2.8.1 Dadyar Dana AI assistant — Gemma + horizontal workspace */
.dana-panel.hidden { display: none !important; }
.dana-workspace-shell {
  min-height: 650px;
  background:
    radial-gradient(circle at 8% 0%, rgba(18, 94, 163, .16), transparent 34%),
    radial-gradient(circle at 92% 12%, rgba(184,135,45,.14), transparent 32%),
    linear-gradient(135deg, #ffffff 0%, #f4f8ff 58%, #fff9ec 100%);
  border-color: rgba(15,76,129,.16);
  overflow: hidden;
}
.dana-panel-title { align-items: flex-start; gap: 16px; }
.dana-panel-title h2 { margin-bottom: 6px; letter-spacing: -.02em; }
.dana-meta-stack { display:flex; flex-direction:column; gap:8px; align-items:flex-start; min-width: 190px; }
.model-badge { background: linear-gradient(135deg,#0f4c81,#173b67); color: #fff; border: 0; }
.dana-workflow-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 10px;
  margin: 14px 0 18px;
}
.dana-step-card {
  display: grid;
  grid-template-columns: 38px 1fr;
  grid-template-areas: 'num title' 'num sub';
  align-items: center;
  gap: 2px 10px;
  padding: 12px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(15,76,129,.13);
  box-shadow: 0 10px 25px rgba(15,76,129,.06);
}
.dana-step-card span { grid-area:num; width:34px; height:34px; display:grid; place-items:center; border-radius:12px; background:#eef6ff; color:#0f4c81; font-weight:950; }
.dana-step-card strong { grid-area:title; color:var(--navy); font-size:.94rem; }
.dana-step-card small { grid-area:sub; color:#64748b; font-weight:700; font-size:.76rem; line-height:1.6; }
.dana-step-card.active { border-color: rgba(15,76,129,.28); background: linear-gradient(135deg,#fff,#eef6ff); }
.dana-step-card.active span { background: linear-gradient(135deg,#0f4c81,#1976c9); color:#fff; }
.dana-horizontal-board {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(340px, .65fr);
  gap: 16px;
  align-items: stretch;
}
.dana-card, .dana-admin-box {
  border: 1px solid rgba(15,76,129,.13);
  border-radius: 22px;
  background: rgba(255,255,255,.88);
  box-shadow: 0 16px 42px rgba(15,76,129,.08);
  padding: 17px;
}
.dana-card-title { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:10px; }
.dana-card-title h3, .dana-admin-box h3 { margin:0; color: var(--navy); font-size: 1.05rem; }
.mini-badge { display:inline-flex; align-items:center; justify-content:center; padding:6px 10px; border-radius:999px; background:rgba(15,76,129,.09); color:#0f4c81; font-size:.76rem; font-weight:950; white-space:nowrap; }
.mini-badge.gold { background:rgba(184,135,45,.13); color:#805b18; }
.dana-security-note {
  padding: 11px 13px;
  border-radius: 15px;
  background: linear-gradient(135deg, rgba(15,76,129,.09), rgba(184,135,45,.08));
  border: 1px solid rgba(15,76,129,.12);
  color: #173b67;
  font-weight: 850;
  line-height: 1.85;
  margin-bottom: 12px;
  font-size: .88rem;
}
.dana-form-strip { display:grid; grid-template-columns: 150px 120px minmax(220px,1fr); gap:10px; align-items:end; }
.dana-form-strip label { margin:0; }
.dana-file-field small { margin-top:5px; font-size:.76rem; }
.dana-toolbar { display:flex; gap:8px; flex-wrap:wrap; margin:12px 0 10px; }
.dana-toolbar .btn { min-height: 38px; padding: 9px 13px; }
.dana-textarea-label textarea { min-height: 300px; line-height: 2; font-size: .93rem; }
.dana-card-request { display:flex; flex-direction:column; min-height: 100%; }
.dana-card-request .compact-form { margin-bottom: 10px; }
.dana-request-head { margin-top: 10px; padding-top: 10px; border-top: 1px solid rgba(15,76,129,.1); }
.dana-suggestions { margin-top: 12px; display: grid; gap: 10px; max-height: 240px; overflow:auto; padding-left:4px; }
.dana-suggestion-item { border-right: 4px solid #0f4c81; background: linear-gradient(135deg,#fff,#f5f9ff); }
.dana-requests-list { max-height: 420px; overflow: auto; padding-left: 4px; }
.dana-request-item { border-right: 4px solid #b8872d; }
.dana-final-response {
  margin-top: 12px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(39,132,92,.08);
  border: 1px solid rgba(39,132,92,.16);
}
.dana-admin-box { margin-top: 16px; background: linear-gradient(135deg,#f7fbff,#fff); }
.dana-admin-workbench { display: grid; grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)); gap: 14px; }
.dana-admin-item { border-right: 5px solid #0f4c81; background: #fff; }
.dana-ai-editor { direction: rtl; min-height: 260px; font-family: 'DadyarText', Tahoma, Arial, sans-serif; line-height: 2; }
.compact-head { margin-top: 18px; }
.chip-row { display: flex; gap: 8px; flex-wrap: wrap; margin: 8px 0; }
.dana-panel .item-actions { margin: 12px 0; }
@media (max-width: 1180px) { .dana-workflow-row { grid-template-columns: repeat(2, minmax(0,1fr)); } .dana-horizontal-board { grid-template-columns: 1fr; } }
@media (max-width: 720px) { .dana-workflow-row { grid-template-columns: 1fr; } .dana-form-strip { grid-template-columns: 1fr; } .dana-card, .dana-admin-box { padding: 14px; border-radius: 18px; } .dana-meta-stack { align-items:stretch; min-width:0; } }
.workspace-site-links button {
  appearance: none;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  color: #fff;
  padding: 9px 13px;
  background: rgba(255,255,255,.12);
  font: inherit;
  font-weight: 850;
  cursor: pointer;
}
.workspace-site-links button:hover { background: rgba(255,255,255,.22); transform: translateY(-1px); }
@media (max-width: 1080px) { .dana-grid { grid-template-columns: 1fr; } }
@media (max-width: 680px) { .dana-card, .dana-admin-box { padding: 14px; border-radius: 18px; } }


/* v2.8.2 Dadyar Dana layout cleanup and user status markers */
.dana-workflow-row { display: none !important; }
.dana-horizontal-board,
.dana-admin-workbench {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
  align-items: stretch !important;
}
.dana-card,
.dana-admin-box,
.dana-admin-item {
  width: 100%;
  max-width: 100%;
}
.dana-card-title,
.dana-request-head {
  flex-wrap: wrap;
}
.dana-card-request .compact-form {
  display: grid;
  grid-template-columns: minmax(220px, 360px) minmax(320px, 1fr);
  gap: 12px;
  align-items: start;
}
.dana-card-request .compact-form .form-status {
  grid-column: 1 / -1;
}
@media (max-width: 760px) {
  .dana-card-request .compact-form { grid-template-columns: 1fr; }
}
.session-dashboard-link { box-shadow: 0 10px 24px rgba(15,76,129,.16); }
.admin-user-item { position: relative; padding-inline-start: 52px; }
.user-status-tick {
  position: absolute;
  top: 18px;
  inset-inline-start: 16px;
  width: 28px;
  height: 28px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  font-weight: 950;
  color: #fff;
  box-shadow: 0 8px 18px rgba(17,24,39,.12);
  border: 2px solid rgba(255,255,255,.85);
}
.user-status-tick.approved { background: #1f9d55; }
.user-status-tick.pending { background: #d8a21c; }
.user-status-tick.suspended,
.user-status-tick.rejected { background: #c93434; }
.user-status-tick.unknown { background: #64748b; }
.user-status-caption {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-inline-start: 8px;
  font-weight: 900;
}


/* v2.8.3: cleaner library hero and ticket/message readability */
.library-hero-badges { display: none !important; }
.case-status-badge { border: 1px solid transparent; }
.case-status-waiting { background: #fff7cc !important; color: #7a4b00 !important; border-color: #f3d38d !important; }
.case-status-answered { background: #dcfce7 !important; color: #166534 !important; border-color: #86efac !important; }
.case-status-closed { background: #dbeafe !important; color: #1d4ed8 !important; border-color: #93c5fd !important; }
.case-status-default { background: #e6f4ff !important; color: #075985 !important; }
.messages { margin-top: 14px; }
.messages-scroll {
  max-height: 360px;
  overflow-y: auto;
  padding: 10px;
  border: 1px solid rgba(184,135,45,.22);
  border-radius: 22px;
  background: rgba(255,255,255,.78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
}
.message-row { border: 1px solid rgba(15,76,129,.13); border-radius: 18px; margin-bottom: 10px; background: #fff; overflow: hidden; }
.message-summary { width: 100%; border: 0; background: linear-gradient(135deg,#f8fbff,#fff); padding: 12px 14px; display: flex; justify-content: space-between; gap: 14px; align-items: center; cursor: pointer; color: var(--navy); font-family: inherit; text-align: right; }
.message-summary strong { font-size: .94rem; }
.message-summary span { color: #64748b; font-size: .78rem; font-weight: 800; }
.message-body { display: none; margin: 0; padding: 12px 14px 16px; color: #14213d; line-height: 2.05; white-space: pre-wrap; border-top: 1px solid rgba(15,76,129,.08); }
.message-row.expanded .message-body { display: block; }
.warning-text { color: #9a5b00 !important; background: #fff8e6 !important; border: 1px solid rgba(184,135,45,.24) !important; }

/* v2.8.7 - International contracts through secure data proxy */
.international-contract-item .btn { white-space: nowrap; }
.international-contract-item h3 { line-height: 1.8; }
@media (min-width: 900px) {
  .international-contract-item { align-items: center; }
}

/* v2.8.8 judicial archive */
.archive-pager{display:flex;align-items:center;justify-content:center;gap:12px;margin:14px 0;flex-wrap:wrap}
.legal-item-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.judicial-archive-item small{display:block;margin-top:8px;color:var(--muted, #64748b)}
.judgment-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:16px 0}
.judgment-detail-grid>div{background:#f8fafc;border:1px solid rgba(15,23,42,.08);border-radius:16px;padding:14px}
.judgment-detail-grid strong{display:block;margin-bottom:8px;color:#0f172a}
.judgment-sections{display:grid;gap:12px;margin-top:16px}
.judgment-section{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:16px;padding:14px}
.judgment-section h4{margin:0 0 8px;color:#12355b}
.judgment-section p{white-space:pre-wrap;line-height:2;margin:0;color:#1f2937}
@media (max-width: 760px){.judgment-detail-grid{grid-template-columns:1fr}.legal-item-actions{justify-content:flex-start}.archive-pager .btn{flex:1}}

/* v2.8.9: archive/contracts visual polish and public data-source hardening */
.workspace-site-links-empty {
  min-height: 18px;
  padding: 0;
  border: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}
.contracts-body .legal-workspace-main > .legal-panel > .panel {
  position: relative;
  overflow: hidden;
}
.contracts-body .legal-workspace-main > .legal-panel > .panel::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: linear-gradient(90deg, #0f4c81, #1d8cc7, #b8872d, #2f855a);
}
.contracts-body .enhanced-head {
  padding: 4px 0 12px;
  border-bottom: 1px solid rgba(15, 76, 129, .10);
}
.badge-blue { background: #dbeafe !important; color: #1d4ed8 !important; border: 1px solid #93c5fd !important; }
.badge-gold { background: #fff3cd !important; color: #8a5a00 !important; border: 1px solid #f5d889 !important; }
.badge-green { background: #dcfce7 !important; color: #166534 !important; border: 1px solid #86efac !important; }
.international-contract-item,
.judicial-archive-item,
.country-law-card {
  border: 1px solid rgba(15, 76, 129, .12);
  background:
    radial-gradient(circle at 0 0, rgba(29, 140, 199, .08), transparent 28%),
    linear-gradient(135deg, #ffffff 0%, #f8fbff 58%, #fffaf0 100%);
  box-shadow: 0 16px 40px rgba(15, 76, 129, .07);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.international-contract-item:hover,
.judicial-archive-item:hover,
.country-law-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 54px rgba(15, 76, 129, .12);
  border-color: rgba(15, 76, 129, .24);
}
.international-contract-item { border-right: 6px solid #0f4c81; }
.judicial-archive-item { border-right: 6px solid #b8872d; }
.country-law-card { border-right: 6px solid #2f855a; }
.judicial-archive-controls {
  background: linear-gradient(135deg, rgba(15,76,129,.07), rgba(184,135,45,.08));
  border: 1px solid rgba(15,76,129,.10);
  border-radius: 22px;
  padding: 10px;
}
.archive-pager {
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(15,76,129,.10);
  border-radius: 18px;
  padding: 10px;
}
.legal-viewer {
  border: 1px solid rgba(15,76,129,.12);
  background: linear-gradient(135deg,#fff,#f8fbff);
  box-shadow: 0 18px 45px rgba(15,76,129,.08);
}
.countries-regulations-list {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
@media (max-width: 760px) {
  .workspace-site-links-empty { min-height: 12px; }
  .contracts-body .enhanced-head { gap: 12px; }
}

/* v2.8.10 Dana ticket flow and legal draft workspace */
.dana-ticket-form {
  border: 1px solid rgba(184,135,45,.16);
  border-radius: 18px;
  padding: 12px;
  background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,248,232,.86));
}
.dana-ticket-toggle {
  display:flex !important;
  align-items:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(184,135,45,.10);
  border: 1px solid rgba(184,135,45,.18);
  color:#173b67;
  font-weight: 950;
}
.dana-ticket-toggle input { width: 18px; height:18px; accent-color:#0f4c81; }
.dana-request-title-box { min-width: min(100%, 420px); }
.dana-card-pleading {
  border-right: 5px solid #27845c;
  background:
    radial-gradient(circle at 0 0, rgba(39,132,92,.10), transparent 34%),
    linear-gradient(135deg,#ffffff,#f4fff9);
}
.dana-draft-form {
  display: grid;
  grid-template-columns: minmax(260px, 1.2fr) minmax(220px, .8fr) auto;
  gap: 12px;
  align-items: end;
}
.dana-draft-options {
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 8px;
}
.dana-draft-options label {
  margin:0;
  padding: 11px 12px;
  border-radius: 15px;
  border: 1px solid rgba(15,76,129,.12);
  background: rgba(255,255,255,.88);
  font-weight: 900;
  color:#173b67;
}
.dana-draft-options input { accent-color:#0f4c81; margin-inline-end: 6px; }
.dana-request-summary { background: linear-gradient(135deg,#fff,#fffaf1); }
.dana-request-detail {
  margin-top: 12px;
  border-radius: 20px;
  border: 1px solid rgba(15,76,129,.14);
  background: linear-gradient(135deg,#fff,#f5f9ff);
  padding: 10px;
}
.dana-request-opened details {
  margin-top: 10px;
  border: 1px solid rgba(15,76,129,.12);
  border-radius: 16px;
  background: rgba(255,255,255,.78);
  padding: 10px 12px;
}
.dana-request-opened summary { cursor:pointer; color:#0f4c81; font-weight:950; }
.dana-text-preview {
  white-space: pre-wrap;
  overflow:auto;
  max-height: 360px;
  direction: rtl;
  line-height: 2;
  font-family: 'DadyarText', Tahoma, Arial, sans-serif;
  background: #fff;
  border-radius: 14px;
  padding: 12px;
  border: 1px solid rgba(15,76,129,.09);
}
.dana-final-pre { background: #f3fff8; border-color: rgba(39,132,92,.18); }
.dana-trail {
  display:flex;
  flex-wrap:wrap;
  gap: 7px;
  margin-top: 9px;
}
.dana-trail span {
  display:inline-flex;
  align-items:center;
  border-radius: 999px;
  padding: 5px 9px;
  background: rgba(15,76,129,.08);
  color:#173b67;
  font-size: .77rem;
  font-weight: 850;
}
.compact-trail span { font-size:.72rem; }
.badge-waiting { background:#fff7db !important; color:#8a5d00 !important; border-color:#f1c84a !important; }
.badge-answered { background:#e9fbf1 !important; color:#17693f !important; border-color:#7ed2a1 !important; }
.badge-blue { background:#e8f3ff !important; color:#0f4c81 !important; border-color:#7db4e7 !important; }
.badge-closed { background:#e9f0ff !important; color:#1e3a8a !important; border-color:#93b4f4 !important; }
.badge-neutral { background:#f3f4f6 !important; color:#374151 !important; }
@media (max-width: 920px) {
  .dana-draft-form { grid-template-columns: 1fr; }
  .dana-draft-options { grid-template-columns: 1fr; }
}
.dana-card-request .compact-form.dana-ticket-form { grid-template-columns: 1fr !important; }
.dana-card-request .compact-form.dana-ticket-form .form-status { grid-column: auto !important; }

/* v2.8.10-admin-static-preview */
.static-preview-card { margin-bottom: 1rem; }
.admin-pre { background: #f8fafc; border: 1px solid rgba(15, 23, 42, .12); border-radius: 14px; padding: .9rem; overflow: auto; max-height: 260px; direction: ltr; text-align: left; white-space: pre-wrap; font-size: .85rem; }

/* v2.8.10 Pages static typography fix: prefer Vazir on static public pages. */
:root {
  font-family: 'DadyarVazir', 'Vazir', 'Vazirmatn', Tahoma, Arial, sans-serif;
}
body, input, textarea, select, button,
p, li, .subtle, .lead, details p, .service-card p, .card p,
h1, h2, h3, .brand, .eyebrow, .nav-links, .btn, .workspace-tab {
  font-family: 'DadyarVazir', 'Vazir', 'Vazirmatn', Tahoma, Arial, sans-serif;
}
