.elementor-1184 .elementor-element.elementor-element-63ebcab{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}/* Start custom CSS for html, class: .elementor-element-8d84825 */:root{
  --yellow:#FFE400;
  --hero:#474747;
  --gray-900:#111827;
  --gray-800:#2d3748;
  --gray-700:#374151;
  --gray-600:#4b5563;
  --gray-300:#d1d5db;
  --gray-200:#e5e7eb;
  --gray-100:#f7fafc;
  --card:#ffffff;
}

/* Entry Title — global (no .esf) */
.entry-title{
  padding-top:30px;
  margin:0 0 16px;
  color:#2d3748;
  font-weight:700;
  line-height:1.2;
  font-size:clamp(24px,5vw,40px);
  letter-spacing:-0.2px;
  position:relative;
}
.entry-title::after{
  content:"";
  display:block;
  width:clamp(56px,12vw,92px);
  height:4px;
  margin-top:10px;
  border-radius:3px;
  background:linear-gradient(90deg,#FFE400 0%, #667eea 60%, #764ba2 100%);
  box-shadow:0 2px 6px rgba(0,0,0,0.08);
}

/* Base */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
html,body{
  font-family:'IRANSans', system-ui, -apple-system, 'Segoe UI', Roboto, 'Noto Sans', 'Apple Color Emoji','Segoe UI Emoji','Noto Color Emoji', sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  color:var(--gray-800);
  background:var(--gray-100);
  line-height:1.65;
}

/* ========================= Layout Container ========================= */
.ce-container{max-width:1200px;margin:0 auto;padding:0 20px;}

/* ========================= Buttons ========================= */
.ce-btn-primary,.ce-cta-button{
  display:inline-block;background:var(--yellow);color:#111;
  padding:clamp(12px,2vw,16px) clamp(20px,3.4vw,28px);
  border:none;border-radius:12px;font-weight:700;font-size:clamp(14px,1.8vw,16px);
  text-decoration:none;cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
  transition:transform .25s, box-shadow .25s, background-color .25s, color .25s;
}
.ce-btn-primary:hover,.ce-cta-button:hover{
  transform:translateY(-2px); box-shadow:0 12px 28px rgba(0,0,0,.24);
  background:#2d3748; color:#fff;
}
.ce-btn-secondary{
  display:inline-block;background:transparent;color:#fff;
  padding:clamp(12px,2vw,16px) clamp(20px,3.4vw,28px);
  border:2px solid #fff;border-radius:12px;font-weight:700;font-size:clamp(14px,1.8vw,16px);
  text-decoration:none;cursor:pointer;transition:.25s;
}
.ce-btn-secondary:hover{background:#fff;color:var(--hero);}

/* ========================= Header (نمونه ساده) ========================= */
.site-header{background:#fff;border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:50;}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:64px;}
.brand{font-weight:800;color:var(--gray-900);text-decoration:none;}
.nav-links{display:flex;gap:1rem;}
.nav-links a{color:var(--gray-700);text-decoration:none;font-weight:600;}
.nav-links a:hover{color:#000;}

/* ========================= Hero ========================= */
.ce-hero{
  background:var(--hero); color:#fff; text-align:center;
  padding:clamp(80px,10vw,128px) 0 clamp(48px,6vw,64px);
  margin-top:0; position:relative; overflow:hidden;
}
.ce-hero::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(1200px 400px at 50% -10%, rgba(255,228,0,.18), transparent 60%);
  pointer-events:none;
}
.ce-hero h1,.ce-hero h2{
  font-weight:800; font-size:clamp(24px,5vw,40px); line-height:1.2; margin-bottom:1rem; letter-spacing:-.2px;
}
.ce-hero p{
  font-size:clamp(13px,1.8vw,16px); line-height:1.8; opacity:.92; max-width:680px; margin:0 auto 2rem;
}
.ce-hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}

/* ========================= Features ========================= */
.ce-features{padding:clamp(56px,7vw,88px) 0;background:#fff;}
.ce-features h2{ text-align:center;color:var(--gray-800);font-size:clamp(20px,3.2vw,32px);line-height:1.25;margin-bottom:2.5rem; }
.ce-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.6rem;margin-top:2rem;}
.ce-feature-card{
  background:#fff;border:1px solid var(--gray-200);border-radius:16px;
  padding:clamp(18px,2.6vw,24px); text-align:center;
  box-shadow:0 8px 20px rgba(0,0,0,.06);
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.ce-feature-card:hover{transform:translateY(-6px);border-color:var(--hero);box-shadow:0 18px 38px rgba(0,0,0,.12);}
.ce-feature-icon{
  width:76px;height:76px;margin:0 auto 1rem;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--hero);color:#fff;font-size:1.8rem;
  box-shadow:inset 0 0 0 3px rgba(255,228,0,.25);
}
.ce-feature-card h3{color:var(--gray-800);font-size:clamp(16px,2.4vw,20px);line-height:1.3;margin:.4rem 0 .6rem;font-weight:700;}
.ce-feature-card p{color:var(--gray-600);font-size:clamp(13px,1.7vw,15px);line-height:1.8;}

/* ========================= Demo Cards Grid (the <a class="group"> cards) ========================= */
.grid{display:grid;}
.gap-8{gap:2rem;}
@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,1fr);} }
@media (min-width:1024px){.lg\:grid-cols-4{grid-template-columns:repeat(4,1fr);} }

.group{
  display:block;border-radius:16px;overflow:hidden;
  background:linear-gradient(180deg,#fff,#f9fafb);border:1px solid var(--gray-200);
  transition:transform .25s, box-shadow .25s, border-color .25s, background .25s;
}
.group:hover{transform:translateY(-8px);box-shadow:0 22px 46px rgba(0,0,0,.18);border-color:var(--gray-300);background:linear-gradient(180deg,#fff,#f6f7fb);}
.relative{position:relative;}
.overflow-hidden{overflow:hidden;}
.group img{width:100%;height:12rem;object-fit:cover;transition:transform .35s cubic-bezier(.22,.61,.36,1);}
.group:hover img{transform:scale(1.08);}
.bg-gradient-to-t{background-image:linear-gradient(to top, rgba(0,0,0,.7), transparent);}
.opacity-60{opacity:.6;}
.group:hover .group-hover\:opacity-100{opacity:1 !important;}
.transition-opacity{transition:opacity .3s;}
.badge,.bg-opacity-90{background-color:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);}
.text-xs{font-size:.75rem;line-height:1rem;}
.px-2{padding-inline:.5rem;}
.py-1{padding-block:.25rem;}
.absolute{position:absolute;}
.inset-0{inset:0;}
.top-4{top:1rem;}
.right-4{right:1rem;}
.p-6{padding:1.5rem;}
.text-xl{font-size:1.25rem;line-height:1.75rem;}
.mb-2{margin-bottom:.5rem;}
.mb-4{margin-bottom:1rem;}
.leading-relaxed{line-height:1.625;}
.group h3{color:var(--gray-900);font-weight:800;transition:color .25s;}
.group:hover h3{color:#ea580c;}
.group p{color:var(--gray-600);}
.group button{
  width:100%;display:flex;align-items:center;justify-content:space-between;border:0;background:transparent;padding:0;cursor:pointer;
  color:#ea580c;font-weight:700;transition:color .2s, background-color .2s;
}
.group:hover button{color:#9a3412;background:rgba(251,146,60,.10);}
.h-4{height:1rem;}
.w-4{width:1rem;}

/* ========================= Stats ========================= */
.ce-stats{background:#2d3748;color:#fff;padding:4rem 0;}
.ce-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;text-align:center;}
.ce-stat-item h3{font-size:clamp(28px,4vw,48px);font-weight:800;color:#4c51bf;margin-bottom:.5rem;}
.ce-stat-item p{font-size:1.05rem;opacity:.9;}

/* ========================= CTA Section ========================= */
.ce-cta-section{background:#fff;color:#222;text-align:center;padding:4rem 0;position:relative;overflow:hidden;}
.ce-cta-section::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(900px 300px at 50% -5%, rgba(255,228,0,.16), transparent 60%);
  pointer-events:none;
}
.ce-cta-section h2{font-size:clamp(20px,3.2vw,32px);font-weight:800;line-height:1.25;margin-bottom:.8rem;}
.ce-cta-section p{font-size:clamp(13px,1.8vw,15.5px);line-height:1.85;opacity:.94;max-width:800px;margin:0 auto 1.6rem;}

/* ========================= Contact ========================= */
.ce-contact{padding:clamp(64px,8vw,96px) 0;background:#f7fafc;text-align:center;}
.ce-section-title{font-size:clamp(20px,3.2vw,32px);font-weight:800;color:var(--gray-800);margin-bottom:2.5rem;}
.ce-contact-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem;}
.ce-contact-item{
  background:#fff;border:1px solid var(--gray-200);border-radius:14px;padding:1.8rem;
  box-shadow:0 10px 26px rgba(0,0,0,.06);
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.ce-contact-item:hover{transform:translateY(-4px);border-color:var(--hero);box-shadow:0 16px 36px rgba(0,0,0,.12);}
.ce-contact-item h4{font-size:clamp(16px,2.4vw,20px);color:var(--gray-800);margin-bottom:.8rem;font-weight:800;}
.ce-contact-item p,.ce-contact-item a{color:var(--gray-600);font-size:clamp(13px,1.8vw,15px);line-height:1.9;text-decoration:none;}

/* Utilities used in snippet */
.w-full{width:100%;}
.h-48{height:12rem;}
.justify-between{justify-content:space-between;}
.items-center{align-items:center;}
.flex{display:flex;}
.cursor-pointer{cursor:pointer;}
.rounded-lg{border-radius:.75rem;}
.py-20{padding-block:5rem;}
.px-4{padding-inline:1rem;}
@media (min-width:640px){.sm\:px-6{padding-inline:1.5rem;}}
@media (min-width:1024px){.lg\:px-8{padding-inline:2rem;}}
.max-w-7xl{max-width:1200px;margin-inline:auto;}
.text-center{text-align:center;}
.mb-16{margin-bottom:4rem;}
.bg-white{background:#fff;}
.text-gray-900{color:var(--gray-900);}
.text-gray-600{color:var(--gray-600);}
.rounded-full{border-radius:9999px;}
.text-sm{font-size:.875rem;line-height:1.25rem;}
.px-3{padding-inline:.75rem;}
.py-1{padding-block:.25rem;}

/* ========================= Responsive Tweaks ========================= */
@media (max-width:768px){
  .nav-links{display:none;}
  .ce-hero{padding:6rem 0 3rem;}
  .ce-hero p{max-width:90%;line-height:1.9;}
  .ce-features{padding:4.5rem 0;}
  .ce-features-grid{grid-template-columns:1fr;gap:1.2rem;}
  .grid{gap:1.25rem;}
  .p-6{padding:1.25rem;}
}
@media (min-width:769px) and (max-width:1199px){
  .ce-hero p,.ce-feature-card p,.group p{line-height:1.8;}
}
@media (min-width:1200px){
  .ce-hero p,.ce-feature-card p,.group p{line-height:1.75;}
}

/* === Typography tuning for this page === */
.ce-hero h2{font-size:clamp(24px,5vw,36px);line-height:1.2;letter-spacing:-0.2px;}
.ce-features h2,.ce-cta-section h2,.ce-section-title{font-size:clamp(20px,3.2vw,32px);line-height:1.25;letter-spacing:-0.2px;}
.ce-feature-card h3,.group h3{font-size:clamp(16px,2.4vw,20px);line-height:1.3;font-weight:800;letter-spacing:-0.1px;}
.ce-contact-item h4{font-size:clamp(14px,2vw,18px);line-height:1.35;font-weight:800;}
.ce-container p,.group p{font-size:clamp(13px,1.7vw,15px);line-height:1.8;letter-spacing:0;}
@media (max-width:768px){
  .ce-container p,.group p,.ce-container a{line-height:1.9;}
  .ce-hero h2{margin-bottom:.75rem;}
}
@media (min-width:769px) and (max-width:1199px){
  .ce-container p,.group p,.ce-container a{line-height:1.8;}
}
@media (min-width:1200px){
  .ce-container p,.group p,.ce-container a{line-height:1.7;}
}

/* --- Simple sections (no yellow glow) --- */
.rest .ce-hero::before,.rest .ce-cta-section::before{content:none!important;background:none!important;}
.rest .ce-feature-icon{box-shadow:none!important;background:#4c51bf!important;}
.rest .ce-feature-card{box-shadow:0 4px 12px rgba(0,0,0,.06)!important;border-color:#e5e7eb!important;}
.rest .ce-feature-card:hover{box-shadow:0 10px 22px rgba(0,0,0,.10)!important;border-color:#d1d5db!important;}
.rest .ce-btn-primary,.rest .ce-cta-button{box-shadow:none!important;}

/* ===== PATCH: swap orange→yellow, icon boxes → yellow, section glows → gray ===== */
.group:hover h3{color:var(--yellow)!important;}
.group button{color:var(--yellow)!important;}
.group:hover button{color:#b59f00!important;background:rgba(255,228,0,.12)!important;}
.group:hover h3[style],.group button[style]{color:var(--yellow)!important;}
.ce-feature-icon{background:var(--yellow)!important;color:#111!important;box-shadow:inset 0 0 0 3px rgba(0,0,0,.06)!important;}
.ce-stats .ce-stat-item h3{color:var(--yellow)!important;}
.ce-hero::before,.ce-cta-section::before{
  background:radial-gradient(900px 320px at 50% -6%, rgba(0,0,0,.06), transparent 60%)!important;
  content:""!important;
}
.group:hover button,.group button:hover{background:rgba(255,228,0,.12)!important;}
.group:hover{box-shadow:0 22px 46px rgba(0,0,0,.18), 0 10px 26px rgba(255,228,0,.10)!important;}

/* === REST PAGE PATCH (scoped overrides) === */
.rest .ce-hero h1,.rest .ce-hero h2,.rest .text-4xl,.rest .md\:text-5xl{
  font-size:clamp(24px,5vw,36px)!important;line-height:1.2!important;letter-spacing:-0.2px!important;
}
.rest .ce-features h2,.rest .ce-cta-section h2,.rest .ce-section-title{
  font-size:clamp(20px,3.2vw,32px)!important;line-height:1.25!important;letter-spacing:-0.2px!important;
}
.rest .ce-feature-card h3,.rest .group h3{font-size:clamp(16px,2.4vw,20px)!important;line-height:1.3!important;font-weight:800!important;}
.rest .ce-contact-item h4{font-size:clamp(14px,2vw,18px)!important;line-height:1.35!important;font-weight:800!important;}
.rest .ce-container p,.rest .group p,.rest .text-xl{font-size:clamp(13px,1.7vw,15px)!important;line-height:1.8!important;letter-spacing:0!important;}
.rest .ce-container a,.rest .group button,.rest .ce-btn-primary,.rest .ce-btn-secondary{font-size:clamp(13px,1.8vw,15px)!important;line-height:1.6!important;}
.rest .group:hover h3{color:var(--yellow)!important;}
.rest .group button{color:var(--yellow)!important;}
.rest .group:hover button{color:#b59f00!important;background:rgba(255,228,0,.12)!important;}
.rest .text-orange-600{color:var(--yellow)!important;}
.rest .hover\:text-orange-700:hover{color:#b59f00!important;}
.rest .hover\:bg-orange-50:hover{background:rgba(255,228,0,.12)!important;}
.rest .ce-feature-icon{background:var(--yellow)!important;color:#111!important;box-shadow:inset 0 0 0 3px rgba(0,0,0,.06)!important;}
.rest .ce-hero::before,.rest .ce-cta-section::before{
  content:""!important;
  background:radial-gradient(900px 320px at 50% -6%, rgba(0,0,0,.06), transparent 60%)!important;
  pointer-events:none!important;
}
.rest .ce-stats .ce-stat-item h3{color:var(--yellow)!important;}
.rest .ce-feature-card{box-shadow:0 4px 12px rgba(0,0,0,.06)!important;border-color:#e5e7eb!important;}
.rest .ce-feature-card:hover{box-shadow:0 10px 22px rgba(0,0,0,.10)!important;border-color:#d1d5db!important;}
.rest .ce-btn-primary,.rest .ce-cta-button{box-shadow:none!important;}

@media (min-width:1200px){.ce-hero p,.ce-feature-card p,.group p{line-height:1.75;}}
@media (max-width:768px){
  .ce-hero{padding:5.5rem 0 3rem;}
  .ce-hero p{max-width:92%;line-height:1.9;}
  .ce-features{padding:4rem 0;}
  .ce-features-grid{grid-template-columns:1fr;gap:1.1rem;}
  .grid{gap:1.1rem;}
  .p-6{padding:1.1rem;}
}
@media (min-width:769px) and (max-width:1199px){
  .ce-hero p,.ce-feature-card p,.group p{line-height:1.85;}
  .ce-features-grid{gap:1.4rem;}
}
/* ==== Contact Section (ESF scoped) ==== */
.contact.esf {
padding: 6rem 0;
background: #f7fafc;
text-align: center;
}

.contact.esf .section-title.esf {
color: #2d3748;
margin-bottom: 1rem;
}

.contact.esf > p {
color: #4a5568;
max-width: 720px;
margin: 0 auto 2.5rem;
line-height: 1.9;
}

/* Grid */
.contact-info.esf {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
gap: 1.5rem;
margin-top: 2rem;
}

/* Card */
.contact-item.esf {
padding: 1.8rem;
background: #fff;
border-radius: 12px;
box-shadow: 0 4px 15px rgba(0,0,0,0.05);
transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
border: 1px solid rgba(0,0,0,0.045);
}

.contact-item.esf:hover {
transform: translateY(-4px);
box-shadow: 0 10px 28px rgba(0,0,0,0.08);
border-color: rgba(0,0,0,0.08);
}

/* Card title + body */
.contact-item.esf h4 {
font-weight: 800;
color: #2d3748;
margin-bottom: .8rem;
}

.contact-item.esf p {
color: #4a5568;
margin: .2rem 0;
}

/* Phone links /
.contact-item.esf a[href^="tel:"] {
display: inline-block;
margin: .25rem 0;
padding: .55rem .9rem;
border-radius: 10px;
background: #f7fafc;
border: 1px solid rgba(0,0,0,0.06);
text-decoration: none;
transition: background .2s ease, border-color .2s ease, transform .15s ease;
direction: ltr; / اعداد خواناتر /
unicode-bidi: plaintext; / جلوگیری از به‌هم‌ریختگی اعداد در RTL */
font-weight: 700;
color: #2d3748;
}

.contact-item.esf a[href^="tel:"]:hover {
background: #fffbe6;
border-color: #ffe58f;
transform: translateY(-1px);
}

.contact-item.esf a[href^="tel:"]:focus-visible {
outline: 3px solid rgba(255,228,0,.45);
outline-offset: 2px;
}

/* Bottom CTA inside contact section */
.contact.esf .cta-button.esf {
margin-top: .5rem;
box-shadow: 0 6px 18px rgba(0,0,0,0.12);
}

.contact.esf .cta-button.esf:focus-visible {
outline: 3px solid rgba(255,228,0,.5);
outline-offset: 2px;
}

/* Responsive tweaks */
@media (max-width: 768px) {
.contact.esf { padding: 3.5rem 0; }
.contact-info.esf { gap: 1rem; }
.contact-item.esf { padding: 1.4rem; }
.contact.esf .cta-button.esf {
display: inline-flex;
width: 100%;
justify-content: center;
}
}/* === Contact CTA Button (scoped to contact section) === */
.contact.esf .cta-button.esf {
  /* visual */
  background: #FFE400;
  color: #1a1a1a;
  border: 1px solid #f6d800;
  border-radius: 40px;

  /* sizing & layout */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: clamp(12px, 2.4vw, 16px) clamp(22px, 4.6vw, 28px);

  /* type & effects */
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 8px 22px rgba(0,0,0,.12);
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, filter .18s ease;
}

.contact.esf .cta-button.esf:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(0,0,0,.16);
  filter: saturate(1.05) brightness(1.02);
}

.contact.esf .cta-button.esf:active {
  transform: translateY(0);
  box-shadow: 0 6px 18px rgba(0,0,0,.12) inset, 0 6px 18px rgba(0,0,0,.12);
}

.contact.esf .cta-button.esf:focus-visible {
  outline: 3px solid rgba(255,228,0,.6);
  outline-offset: 2px;
}

/* Optional: full-width on small screens (keeps your earlier behavior) */
@media (max-width: 768px) {
  .contact.esf .cta-button.esf {
    width: 100%;
  }
}

/* Respect reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
  .contact.esf .cta-button.esf {
    transition: none;
  }
}/* End custom CSS */