/*
Theme Name: Kavan InsurTech Elementor
Theme URI: https://example.com
Author: Kavan
Author URI: https://example.com
Description: قالب اختصاصی نوآوران هوش کاوان — سامانه هوشمند ارزیابی خسارت درمان. با فعال‌سازی، همه صفحات به‌همراه هدر و فوتر سراسری به‌صورت خودکار با المنتور ساخته می‌شوند. (نیازمند افزونه Elementor)
Version: 1.2.0
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kavan
Tags: elementor, rtl, business, dark
*/

html { background:#050A18; }
body { margin:0; font-family:"Vazirmatn",Tahoma,sans-serif; color:#fff; background:#050A18; }
a { color:#67E8F9; }

/* ---- Global floating pill header (overlays content) ---- */
.kavan-header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; justify-content:center;
  padding:14px 16px; pointer-events:none;
}
.kavan-header__inner{ width:min(1080px,100%); pointer-events:auto; }
.kavan-pill{
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
}
.kavan-footer{ margin-top:0; }

/* three-dots button + mobile logo are injected by JS; hidden on desktop, shown on phones */
.kavan-burger{ display:none; }
.kavan-mlogo{ display:none; }

/* Home hero fills the viewport; the fixed header floats over it. */
.kavan-hero{ min-height:100vh; }

/* never allow the wide curve shape-divider to cause sideways scroll */
html, body{ overflow-x:hidden; }

/* =================== Mobile / responsive =================== */
@media (max-width:1024px){
  /* tablet: stop the floating pill from getting too wide/tight */
  .kavan-header__inner{ width:100%; }
}

@media (max-width:767px){
  /* PHONE HEADER: the whole desktop Elementor pill is HIDDEN and replaced by a
     slim bar we render ourselves — a floating logo + a three-dots button. The
     dots open a full-screen overlay menu (.kavan-mnav). */
  .kavan-header{ position:sticky; top:0; padding:12px 16px; pointer-events:auto; }
  .kavan-header__inner{ position:relative; width:100%; min-height:44px; }
  /* hide the entire Elementor header template on phones (every possible wrapper) */
  .kavan-header__inner > .elementor,
  .kavan-header .kavan-pill,
  .kavan-header .elementor-section{ display:none !important; }

  /* our own floating logo (injected by JS), kept readable over any background */
  .kavan-mlogo{
    display:block; position:absolute; right:2px; top:50%; transform:translateY(-50%);
    color:#fff; font-weight:800; font-size:16px; white-space:nowrap;
    text-shadow:0 1px 8px rgba(0,0,0,0.55); pointer-events:none;
  }

  /* the three-dots button (injected by JS) — floats on the left, its own little chip */
  .kavan-burger{
    display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px;
    position:absolute; top:50%; left:2px; transform:translateY(-50%); z-index:1300;
    width:42px; height:42px; border-radius:12px; cursor:pointer;
    background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.20);
    transition:background .25s ease, border-color .25s ease;
  }
  .kavan-burger:active{ background:rgba(255,255,255,0.18); }
  .kavan-burger span{
    width:5px; height:5px; border-radius:50%; background:#fff;
    transition:transform .25s ease, opacity .25s ease, width .25s ease, height .25s ease, border-radius .25s ease;
  }
  /* dots morph into an ✕ (close) when the overlay is open */
  .kavan-header.kavan-nav-open .kavan-burger{
    background:linear-gradient(135deg,#22D3EE,#2563EB); border-color:transparent;
  }
  .kavan-header.kavan-nav-open .kavan-burger span{ position:absolute; left:50%; top:50%; width:22px; height:2px; border-radius:2px; }
  .kavan-header.kavan-nav-open .kavan-burger span:nth-child(1){ transform:translate(-50%,-50%) rotate(45deg); }
  .kavan-header.kavan-nav-open .kavan-burger span:nth-child(2){ opacity:0; }
  .kavan-header.kavan-nav-open .kavan-burger span:nth-child(3){ transform:translate(-50%,-50%) rotate(-45deg); }

  /* FULL-SCREEN OVERLAY MENU (built + populated by JS from the nav + CTA) */
  .kavan-mnav{
    display:flex; position:fixed; inset:0; z-index:1200;
    align-items:center; justify-content:center; padding:80px 24px 40px;
    background:rgba(5,10,24,0.94);
    -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px);
    opacity:0; pointer-events:none; transition:opacity .3s ease;
  }
  .kavan-header.kavan-nav-open ~ .kavan-mnav,
  .kavan-mnav.is-open{ opacity:1; pointer-events:auto; }
  .kavan-mnav__inner{ display:flex; flex-direction:column; align-items:center; gap:26px; width:100%; }
  .kavan-mnav__link{ color:#fff !important; font-size:23px; font-weight:700; text-decoration:none; transition:color .2s ease; }
  .kavan-mnav__link:active{ color:#67E8F9 !important; }
  .kavan-mnav__cta{
    margin-top:8px; display:inline-block; color:#fff !important; text-decoration:none;
    font-size:18px; font-weight:800; padding:14px 34px; border-radius:14px;
    background:linear-gradient(135deg,#22D3EE,#2563EB);
  }

  /* heroes: the slim bar is in normal flow now, so no overlay clearance needed */
  .kavan-hero{ min-height:auto !important; }
  .kavan-hero-sec{ padding-top:36px !important; padding-bottom:56px !important; }

  /* gentler spacing + readable single-post body on phones */
  .kavan-article{ margin-top:24px; }
  .kavan-blog-page{ margin-top:24px; }
}
/* overlay element hidden entirely on tablet/desktop */
@media (min-width:768px){ .kavan-mnav{ display:none !important; } }

/* Uniform image thumbnails for native Image widgets (news cards) */
.kavan-thumb img{ width:100%; height:200px; object-fit:cover; display:block; }

/* ---- Dynamic weblog grid (rendered by the [kavan_latest_posts] shortcode) ---- */
.kavan-blog-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px; text-align:right;
}
.kavan-blog-card{
  background:#FFFFFF; border:1px solid #E3E9F2; border-radius:20px; overflow:hidden;
  box-shadow:0 16px 40px rgba(16,33,73,0.08); display:flex; flex-direction:column;
}
.kavan-blog-card img{ width:100%; height:200px; object-fit:cover; display:block; }
.kavan-blog-noimg{ display:block; height:200px; background:linear-gradient(135deg,#67E8F9,#2563EB); }
.kavan-blog-body{ padding:22px; display:flex; flex-direction:column; gap:12px; flex:1; }
.kavan-blog-meta{ color:#2563EB; font-size:12px; font-weight:700; }
.kavan-blog-card h3{ color:#0B1B33; font-size:19px; line-height:1.6; margin:0; }
.kavan-blog-card h3 a{ color:inherit; text-decoration:none; }
.kavan-blog-card p{ color:#46536E; font-size:14px; line-height:1.9; margin:0; flex:1; }
.kavan-blog-link{ color:#2563EB; font-weight:700; text-decoration:none; margin-top:auto; }
@media (max-width:768px){ .kavan-blog-grid{ grid-template-columns:1fr; } }

/* ---- Weblog "featured + side list" (home) ---- */
.kavan-blog-featured{
  display:grid; grid-template-columns:1.45fr 1fr; gap:22px; text-align:right;
  align-items:stretch;
}
.kavan-feat-main{
  background:#FFFFFF; border:1px solid #E3E9F2; border-radius:22px; overflow:hidden;
  box-shadow:0 18px 44px rgba(16,33,73,0.10); display:flex; flex-direction:column;
}
.kavan-feat-main > a{ display:block; }
.kavan-feat-main > a img, .kavan-feat-main > a .kavan-blog-noimg{
  width:100%; height:300px; object-fit:cover; display:block;
}
.kavan-feat-body{ padding:28px; display:flex; flex-direction:column; gap:12px; }
.kavan-feat-body h3{ color:#0B1B33; font-size:25px; line-height:1.5; margin:0; }
.kavan-feat-body h3 a{ color:inherit; text-decoration:none; }
.kavan-feat-body p{ color:#46536E; font-size:15px; line-height:2; margin:0; }
.kavan-feat-side{ display:flex; flex-direction:column; gap:16px; }
.kavan-feat-row{
  background:#FFFFFF; border:1px solid #E3E9F2; border-radius:18px;
  box-shadow:0 10px 26px rgba(16,33,73,0.06); display:flex; gap:14px; padding:12px;
  align-items:center; flex:1;
}
.kavan-feat-thumb{ flex:0 0 100px; display:block; }
.kavan-feat-thumb img, .kavan-feat-thumb .kavan-blog-noimg{
  width:100px; height:100px; border-radius:14px; object-fit:cover; display:block;
}
.kavan-feat-row h4{ color:#0B1B33; font-size:16px; line-height:1.6; margin:6px 0; }
.kavan-feat-row h4 a{ color:inherit; text-decoration:none; }
.kavan-feat-row p{ color:#6B7793; font-size:13px; line-height:1.7; margin:0; }
@media (max-width:768px){
  .kavan-blog-featured{ grid-template-columns:1fr; }
  .kavan-feat-main > a img, .kavan-feat-main > a .kavan-blog-noimg{ height:220px; }
}

/* ---- Blog index + single post (theme fallback templates) ---- */
.kavan-blog-page{ max-width:1180px; margin:120px auto 80px; padding:0 20px; }
.kavan-blog-page .kavan-blog-title{ color:#0B1B33; text-align:center; margin:0 0 36px; }
.kavan-article{ max-width:820px; margin:120px auto 80px; padding:0 20px; text-align:right; }
.kavan-article h1{ color:#0B1B33; line-height:1.3; }
.kavan-article-meta{ color:#2563EB; font-weight:700; font-size:13px; margin:8px 0 20px; }
.kavan-article-img{ width:100%; border-radius:20px; margin:0 0 24px; }
.kavan-article-body{ color:#46536E; font-size:17px; line-height:2.1; }
.kavan-article-body a{ color:#2563EB; }

.kavan-fallback{ max-width:760px; margin:80px auto; padding:0 20px; text-align:center; }

/* ============================================================
   GRAPHIC ENHANCEMENTS — animated stats, hovers, scroll reveals
   (native widgets get hover/reveal via these baked classes)
   ============================================================ */

/* ---- animated stats band (4 boxes, count-up, hover pop) ---- */
.kavan-stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px; text-align:center;
}
.kavan-stat{
  background:#FFFFFF; border:1px solid #E3E9F2; border-radius:22px;
  padding:26px 18px; box-shadow:0 16px 40px rgba(16,33,73,0.08);
}
.kavan-stat__num{
  color:#2563EB; font-size:34px; font-weight:800; line-height:1.15;
  display:inline-block; transition:transform .3s ease, color .3s ease;
}
.kavan-stat__label{ color:#6B7793; font-size:13.5px; margin-top:8px; }
.kavan-stat:hover{
  box-shadow:0 24px 54px rgba(37,99,235,0.18); border-color:rgba(37,99,235,0.45);
}
.kavan-stat:hover .kavan-stat__num{ transform:scale(1.09); color:#1D4ED8; }
@media (max-width:880px){ .kavan-stats{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .kavan-stats{ grid-template-columns:1fr; } }

/* ---- card hover: dynamic news/weblog cards (shadow grow + image zoom) ---- */
.kavan-stat,.kavan-flip,.kavan-blog-card,.kavan-feat-main,.kavan-feat-row{
  transition:opacity .6s ease, transform .6s ease, box-shadow .35s ease;
}
.kavan-blog-card:hover,.kavan-feat-main:hover{ box-shadow:0 28px 64px rgba(16,33,73,0.18); }
.kavan-feat-row:hover{ box-shadow:0 20px 44px rgba(16,33,73,0.14); }
.kavan-blog-card a,.kavan-feat-main > a{ overflow:hidden; display:block; }
.kavan-blog-card a img,.kavan-feat-main > a img{ transition:transform .5s ease; }
.kavan-blog-card:hover a img,.kavan-feat-main:hover > a img{ transform:scale(1.07); }

/* ---- white grid cards (services/values/team/process) hover lift ---- */
.kavan-card > .elementor-element-populated{ transition:transform .3s ease, box-shadow .3s ease; }
.kavan-card:hover > .elementor-element-populated{
  transform:translateY(-6px); box-shadow:0 26px 60px rgba(16,33,73,0.16);
}

/* ---- process step boxes: hover lift + an accent bar sweeps across the top ---- */
.kavan-step > .elementor-element-populated{ position:relative; overflow:hidden; }
.kavan-step > .elementor-element-populated::before{
  content:""; position:absolute; top:0; right:0; left:0; height:4px;
  background:linear-gradient(90deg,#67E8F9,#2563EB);
  transform:scaleX(0); transform-origin:right; transition:transform .4s ease;
}
.kavan-step:hover > .elementor-element-populated::before{ transform:scaleX(1); }

/* ---- icon-box: framed circle fills with the brand gradient on hover ---- */
.elementor-widget-icon-box .elementor-icon{
  transition:background-image .35s ease, color .35s ease, transform .35s ease, box-shadow .35s ease;
}
.elementor-widget-icon-box:hover .elementor-icon{
  background-image:linear-gradient(135deg,#67E8F9,#2563EB); border-color:transparent;
  color:#04121F; transform:translateY(-4px); box-shadow:0 14px 30px rgba(37,99,235,0.30);
}
.elementor-widget-icon-box:hover .elementor-icon svg{ fill:#04121F; }

/* ---- buttons: subtle lift + glow on hover ---- */
.elementor-button{ transition:transform .25s ease, box-shadow .25s ease, filter .25s ease; }
.elementor-button:hover{
  transform:translateY(-2px); box-shadow:0 12px 28px rgba(37,99,235,0.32); filter:brightness(1.05);
}

/* ---- flip cards (news/weblog grid): image front, details on the back ---- */
.kavan-flip{ background:transparent; border:0; box-shadow:none; perspective:1300px; height:380px; }
.kavan-flip__inner{
  position:relative; width:100%; height:100%; transform-style:preserve-3d;
  transition:transform .75s cubic-bezier(.2,.7,.2,1);
}
.kavan-flip:hover .kavan-flip__inner,
.kavan-flip:focus-within .kavan-flip__inner{ transform:rotateY(180deg); }
.kavan-flip__front,.kavan-flip__back{
  position:absolute; inset:0; -webkit-backface-visibility:hidden; backface-visibility:hidden;
  border-radius:20px; overflow:hidden; display:flex; flex-direction:column;
}
.kavan-flip__front{ background:#0A1426; border:1px solid #E3E9F2; box-shadow:0 16px 40px rgba(16,33,73,0.08); }
/* front: full-bleed thumbnail with the title overlaid on a gradient at the bottom */
.kavan-flip__img{ position:absolute; inset:0; display:block; }
.kavan-flip__img img,.kavan-flip__img .kavan-blog-noimg{
  width:100%; height:100%; object-fit:cover; display:block;
}
.kavan-flip__fronthead{
  position:absolute; left:0; right:0; bottom:0; padding:22px 22px;
  background:linear-gradient(to top, rgba(5,10,24,0.94), rgba(5,10,24,0.45) 60%, rgba(5,10,24,0));
}
.kavan-flip__fronthead h3{
  color:#FFFFFF; font-size:18px; line-height:1.6; margin:0;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}
.kavan-flip__fronthead h3 a{ color:inherit; text-decoration:none; }
/* back: title + description + read-more button, date pinned bottom-left */
.kavan-flip__back{
  transform:rotateY(180deg); background:linear-gradient(150deg,#0E1A30,#0A1426);
  border:1px solid #1E2C49; box-shadow:0 18px 44px rgba(5,10,24,0.30);
  padding:28px; padding-bottom:52px; text-align:right; justify-content:center; gap:12px;
}
.kavan-flip__btitle{ color:#FFFFFF; font-size:19px; line-height:1.5; margin:0; }
.kavan-flip__back p{ color:#C7D2E5; font-size:14px; line-height:1.95; margin:0; }
.kavan-flip__btn{
  align-self:flex-start; display:inline-block; margin-top:4px;
  background:linear-gradient(135deg,#67E8F9,#2563EB); color:#04121F;
  font-weight:800; font-size:13px; padding:10px 20px; border-radius:12px; text-decoration:none;
  transition:filter .2s ease, transform .2s ease;
}
.kavan-flip__btn:hover{ filter:brightness(1.06); transform:translateY(-1px); }
.kavan-flip__date{ position:absolute; bottom:18px; left:24px; color:#67E8F9; }
@media (max-width:768px){
  /* hover-flip can't work on touch — stack the front + back so all info shows */
  .kavan-flip{ height:auto; perspective:none; }
  .kavan-flip__inner{ transform:none !important; }
  .kavan-flip__front,.kavan-flip__back{
    position:relative; inset:auto; transform:none !important;
    -webkit-backface-visibility:visible; backface-visibility:visible;
  }
  /* front children are absolute, so give the front an explicit height on phones */
  .kavan-flip__front{ border-radius:20px 20px 0 0; height:230px; }
  .kavan-flip__back{ border-radius:0 0 20px 20px; }
}

/* ---- publish date moved to the bottom-left on the featured weblog cards ---- */
.kavan-feat-main{ position:relative; }
.kavan-feat-body{ padding-bottom:48px; }
.kavan-feat-main .kavan-blog-meta{ position:absolute; left:24px; bottom:18px; }
.kavan-feat-row > div{ display:flex; flex-direction:column; }
.kavan-feat-row .kavan-blog-meta{ order:9; margin-top:6px; }

/* ---- radial dashboard gauges (conic-gradient ring + count-up centre) ---- */
@property --val{ syntax:'<number>'; initial-value:0; inherits:true; }
.kavan-gauges{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.kavan-gauge{
  text-align:center; --val:var(--target,0);   /* filled by default (editor / no-JS) */
  transition:opacity .6s ease, transform .6s ease;
}
@keyframes kavanFill{ from{ --val:0; } to{ --val:var(--target,0); } }
.kavan-js .kavan-in.kavan-gauge{ animation:kavanFill 1.6s cubic-bezier(.2,.7,.2,1) both; }
.kavan-gauge__ring{
  position:relative; width:172px; height:172px; border-radius:50%; margin:0 auto 16px;
  background:conic-gradient(from 0deg,#67E8F9,#2563EB calc(var(--val)*1%),#E2E9F4 calc(var(--val)*1%));
}
.kavan-gauge__ring::before{
  content:""; position:absolute; inset:15px; background:#ECF1F8; border-radius:50%;
  box-shadow:inset 0 2px 10px rgba(16,33,73,0.08);
}
.kavan-gauge__num{ position:absolute; inset:0; display:grid; place-items:center; }
.kavan-gauge__pct{ font-size:34px; font-weight:800; color:#1D4ED8; display:inline-block; }
.kavan-gauge__label{ color:#46536E; font-size:15px; font-weight:600; }
@media (max-width:768px){ .kavan-gauges{ grid-template-columns:1fr; gap:30px; } }

/* gauges on a DARK section (moved into the analytics band) */
.kavan-gauges--dark .kavan-gauge__ring{
  background:conic-gradient(from 0deg,#67E8F9,#2563EB calc(var(--val)*1%),rgba(255,255,255,0.10) calc(var(--val)*1%));
}
.kavan-gauges--dark .kavan-gauge__ring::before{ background:#0A1426; box-shadow:inset 0 2px 12px rgba(0,0,0,0.4); }
.kavan-gauges--dark .kavan-gauge__pct{ color:#A5F3FC; }
.kavan-gauges--dark .kavan-gauge__label{ color:#B7C2D6; }

/* ---- reveal-on-scroll (only when JS is on, so content never hides without JS) ---- */
.kavan-js .kavan-stat,
.kavan-js .kavan-flip,
.kavan-js .kavan-gauge,
.kavan-js .kavan-blog-card,
.kavan-js .kavan-feat-main,
.kavan-js .kavan-feat-row{ opacity:0; transform:translateY(18px); }
.kavan-js .kavan-in{ opacity:1; transform:none; }

/* ---- Body width: content fills 80% of the screen (10% gutter each side) ---- */
.elementor-section.elementor-section-boxed > .elementor-container{ max-width:80% !important; }

/* ===== Phone box fixes: proper width, RTL alignment, and sizing ===== */
@media (max-width:767px){
  /* the 80% gutters cramp the boxes on a phone — use almost the full width */
  .elementor-section.elementor-section-boxed > .elementor-container{ max-width:94% !important; }

  /* hide the «پلتفرم هوشمند کاوان» section on phones */
  .kavan-platform{ display:none !important; }

  /* keep all stacked boxes properly right-to-left (icon + title + text right-aligned) */
  .kavan-card .elementor-icon-box-wrapper,
  .kavan-step .elementor-icon-box-wrapper{ text-align:right !important; direction:rtl; }
  .kavan-card .elementor-icon-box-icon,
  .kavan-step .elementor-icon-box-icon{ margin-right:0 !important; margin-left:auto !important; }

  /* give stacked cards a bit more breathing room + readable sizing */
  .kavan-card > .elementor-element-populated,
  .kavan-step > .elementor-element-populated{ padding:26px 22px !important; }
  .kavan-stat{ padding:22px 16px; }
  .kavan-stat__num{ font-size:30px; }
  .kavan-gauges{ gap:26px; }
}

/* (Full-page scroll snapping was removed — it broke the section layout.) */

/* Elementor EDITOR canvas doesn't run our reveal JS — keep these visible while
   editing (the live front-end reveals them on scroll as normal). */
.elementor-editor-active .kavan-stat,
.elementor-editor-active .kavan-flip,
.elementor-editor-active .kavan-gauge,
.elementor-editor-active .kavan-blog-card,
.elementor-editor-active .kavan-feat-main,
.elementor-editor-active .kavan-feat-row{ opacity:1 !important; transform:none !important; }
