
:root{
  --bg:#0a0612;
  --bg-2:#120a1f;
  --surface:#160d28;
  --surface-2:#1d1235;
  --line:rgba(160,120,255,.14);
  --violet:#7c3aed;
  --violet-bright:#9d5cff;
  --violet-soft:#b794ff;
  --violet-glow:rgba(124,58,237,.45);
  --text:#f2ecff;
  --text-dim:#a99cc8;
  --text-faint:#6f6488;
  --gold:#f5b942;
  --header-bg:rgba(10,6,18,.7);
  --fx-1:rgba(124,58,237,.30);
  --fx-2:rgba(157,92,255,.18);
  --grain-opacity:.04;
  --radius:20px;
  --maxw:1200px;
  color-scheme:dark;
}

/* ===== LIGHT THEME ===== */
html[data-theme="light"]{
  --bg:#f6f4fb;
  --bg-2:#ffffff;
  --surface:#ffffff;
  --surface-2:#f1ebfc;
  --line:rgba(124,58,237,.16);
  --violet:#7c3aed;
  --violet-bright:#7c3aed;
  --violet-soft:#6d28d9;
  --violet-glow:rgba(124,58,237,.22);
  --text:#1b1330;
  --text-dim:#574d70;
  --text-faint:#8a8099;
  --gold:#c98a12;
  --header-bg:rgba(255,255,255,.75);
  --fx-1:rgba(124,58,237,.12);
  --fx-2:rgba(157,92,255,.10);
  --grain-opacity:.02;
  color-scheme:light;
}

/* smooth color transition when switching themes */
body,header,.feat-card,.price-card,.blog-card,.faq-item,.mini-card,
.side-box,.legal-toc,.about-stat,.value-card,.search-input input,
.cat-select,.btn-ghost,.theme-toggle{
  transition:background-color .35s ease,border-color .35s ease,color .35s ease;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'IRANYekanXFaNum',sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.8;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ===== background atmosphere ===== */
.bg-fx{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none}
.bg-fx::before{
  content:'';position:absolute;width:700px;height:700px;border-radius:50%;
  top:-200px;right:-150px;
  background:radial-gradient(circle,var(--fx-1),transparent 65%);
  filter:blur(40px);
}
.bg-fx::after{
  content:'';position:absolute;width:600px;height:600px;border-radius:50%;
  top:600px;left:-200px;
  background:radial-gradient(circle,var(--fx-2),transparent 65%);
  filter:blur(40px);
}
.grain{position:fixed;inset:0;z-index:-1;opacity:var(--grain-opacity);pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ===== nav ===== */
header{position:sticky;top:0;z-index:1000;backdrop-filter:blur(16px);
  background:var(--header-bg);border-bottom:1px solid var(--line);}
nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{height:38px;width:auto}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{color:var(--text-dim);font-size:.95rem;font-weight:500;transition:color .2s;position:relative}
.nav-links a:hover{color:var(--text)}
.nav-links a::after{content:'';position:absolute;bottom:-6px;right:0;width:0;height:2px;background:var(--violet-bright);transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;gap:14px;align-items:center}
.btn{font-family:inherit;font-weight:600;font-size:.95rem;cursor:pointer;border:none;
  padding:11px 22px;border-radius:12px;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex;align-items:center;gap:8px}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--violet-bright);color:var(--violet-soft)}
.btn-primary{background:linear-gradient(135deg,var(--violet),var(--violet-bright));color:#fff;
  box-shadow:0 8px 28px -8px var(--violet-glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 36px -8px var(--violet-glow)}
.btn-lg{padding:16px 34px;font-size:1.05rem;border-radius:14px}
.theme-toggle{width:44px;height:44px;padding:0;flex-shrink:0;background:transparent;color:var(--text);
  border:1px solid var(--line);border-radius:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.theme-toggle:hover{border-color:var(--violet-bright);color:var(--violet-soft)}
.theme-toggle svg{width:20px;height:20px}
.theme-toggle .icon-moon{display:none}
html[data-theme="light"] .theme-toggle .icon-sun{display:none}
html[data-theme="light"] .theme-toggle .icon-moon{display:block}
.hamburger{display:none;background:none;border:none;color:var(--text);cursor:pointer;flex-direction:column;gap:5px}
.hamburger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s}

/* ===== hero ===== */
.hero{padding:90px 0 70px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--surface);
  border:1px solid var(--line);padding:8px 16px;border-radius:100px;font-size:.85rem;
  color:var(--violet-soft);margin-bottom:26px}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80}
.hero h1{font-size:3.5rem;line-height:1.25;font-weight:800;letter-spacing:-.01em;margin-bottom:24px}
.hero h1 .hl{background:linear-gradient(120deg,var(--violet-bright),var(--violet-soft));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.lead{font-size:1.2rem;color:var(--text-dim);max-width:520px;margin-bottom:38px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.hero-note{font-size:.9rem;color:var(--text-faint);display:flex;align-items:center;gap:8px}
.hero-note svg{width:16px;height:16px;color:#4ade80}

/* phone mockup */
.phone-wrap{position:relative;display:flex;justify-content:center;align-items:center}
.phone{width:300px;height:600px;background:linear-gradient(160deg,#1d1235,#140b24);
  border-radius:40px;border:1px solid var(--line);padding:14px;position:relative;
  box-shadow:0 40px 80px -30px rgba(124,58,237,.5),inset 0 1px 0 rgba(255,255,255,.06);
  animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-18px) rotate(-2deg)}}
.phone-screen{width:100%;height:100%;background:linear-gradient(180deg,#241544,#160d28);
  border-radius:28px;overflow:hidden;position:relative}
.ps-banner{height:120px;background:linear-gradient(120deg,var(--violet),var(--violet-bright));position:relative}
.ps-avatar{width:80px;height:80px;border-radius:24px;background:linear-gradient(135deg,#fff,#e9defc);
  position:absolute;bottom:-40px;right:50%;transform:translateX(50%);border:4px solid #160d28;
  display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:var(--violet)}
.ps-body{padding:54px 20px 20px;text-align:center}
.ps-name{font-weight:700;font-size:1.1rem}
.ps-role{color:var(--text-faint);font-size:.8rem;margin-bottom:18px}
.ps-chips{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:18px}
.ps-chip{background:var(--surface-2);border:1px solid var(--line);border-radius:100px;padding:5px 12px;font-size:.72rem;color:var(--violet-soft)}
.ps-btns{display:flex;flex-direction:column;gap:10px}
.ps-btn{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:11px;font-size:.82rem;color:var(--text-dim);text-align:right;display:flex;align-items:center;gap:10px}
.ps-btn .ic{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--violet),var(--violet-bright));flex-shrink:0}
.float-qr{position:absolute;bottom:40px;left:-10px;width:120px;height:120px;background:#fff;border-radius:18px;
  padding:12px;box-shadow:0 24px 48px -16px rgba(0,0,0,.6);animation:float2 5s ease-in-out infinite}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(14px)}}
.float-qr svg{width:100%;height:100%}
/* real card image inside phone frame */
.phone-img{width:300px;height:auto;aspect-ratio:9/16;padding:0;overflow:hidden;
  border-radius:38px;border:1px solid var(--line);background:#000;
  box-shadow:0 40px 90px -30px rgba(124,58,237,.55),0 0 0 1px rgba(255,255,255,.04) inset}
.phone-img img{width:100%;height:100%;object-fit:cover;border-radius:38px;display:block}

/* ===== section shell ===== */
section{position:relative}
.sec{padding:90px 0}
.sec-head{text-align:center;max-width:680px;margin:0 auto 60px}
.sec-tag{color:var(--violet-soft);font-weight:600;font-size:.9rem;letter-spacing:.04em;margin-bottom:14px;display:block}
.sec-head h2{font-size:2.5rem;font-weight:800;line-height:1.35;margin-bottom:16px;letter-spacing:-.01em}
.sec-head p{color:var(--text-dim);font-size:1.1rem}

/* ===== trust bar ===== */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:32px 0;background:var(--bg-2)}
.trust-row{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;color:var(--text-faint);font-size:.95rem;font-weight:500}
.trust-item strong{color:var(--text);font-weight:700;font-size:1.3rem}
.trust-sep{width:1px;height:34px;background:var(--line)}

/* ===== features ===== */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feat-card{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:32px;transition:transform .3s,border-color .3s;position:relative;overflow:hidden}
.feat-card::before{content:'';position:absolute;top:0;right:0;width:140px;height:140px;
  background:radial-gradient(circle,var(--violet-glow),transparent 70%);opacity:0;transition:opacity .3s}
.feat-card:hover{transform:translateY(-6px);border-color:rgba(157,92,255,.4)}
.feat-card:hover::before{opacity:.5}
.feat-ic{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--violet),var(--violet-bright));
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;position:relative;z-index:1}
.feat-ic svg{width:28px;height:28px;color:#fff}
.feat-card h3{font-size:1.3rem;font-weight:700;margin-bottom:12px;position:relative;z-index:1}
.feat-card p{color:var(--text-dim);font-size:.98rem;position:relative;z-index:1}

/* ===== how it works ===== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;position:relative}
.step{text-align:center;position:relative}
.step-num{width:72px;height:72px;border-radius:50%;margin:0 auto 22px;
  background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;font-weight:800;color:var(--violet-bright);position:relative;z-index:2}
.step h3{font-size:1.25rem;margin-bottom:10px}
.step p{color:var(--text-dim);font-size:.96rem;max-width:280px;margin:0 auto}
.steps-line{position:absolute;top:36px;right:16%;left:16%;height:1px;
  background:linear-gradient(90deg,transparent,var(--line),transparent);z-index:1}

/* ===== discover (search + map) ===== */
.discover{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.search-bar{display:flex;gap:12px;max-width:760px;margin:0 auto 14px;flex-wrap:wrap}
.search-input{flex:1;min-width:240px;position:relative}
.search-input svg{position:absolute;right:18px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-faint)}
.search-input input{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:16px 50px 16px 18px;color:var(--text);font-family:inherit;font-size:1rem;transition:border-color .2s}
.search-input input:focus{outline:none;border-color:var(--violet-bright);box-shadow:0 0 0 4px rgba(124,58,237,.12)}
.search-input input::placeholder{color:var(--text-faint)}
.cat-select{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px;
  color:var(--text);font-family:inherit;font-size:1rem;cursor:pointer;min-width:180px}
.cat-select:focus{outline:none;border-color:var(--violet-bright)}
.chip-row{display:flex;gap:10px;max-width:760px;margin:0 auto;overflow-x:auto;padding:2px 2px 6px;
  scrollbar-width:none;-webkit-overflow-scrolling:touch}
.chip-row::-webkit-scrollbar{display:none}
.chip{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;flex-shrink:0;cursor:pointer;
  background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:9px 16px;
  color:var(--text);font-family:inherit;font-size:.9rem;font-weight:600;transition:.18s}
.chip:hover{border-color:var(--violet-bright)}
.chip .chip-dot{width:9px;height:9px;border-radius:50%;background:var(--violet);flex-shrink:0}
.chip.chip-active{background:var(--violet);border-color:var(--violet);color:#fff}
.chip.chip-active .chip-dot{display:none}
.discover-toggle{display:flex;max-width:420px;margin:16px auto 0;background:var(--surface);
  border:1px solid var(--line);border-radius:999px;padding:4px}
.dt-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;
  font-family:inherit;font-size:.92rem;font-weight:700;color:var(--text-dim);background:transparent;
  border:none;border-radius:999px;padding:10px;transition:.18s}
.dt-btn svg{width:17px;height:17px}
.dt-btn.dt-active{background:var(--violet);color:#fff}
/* Tab-based discover: one full-width pane at a time (map OR list), all widths. */
.discover-layout{position:relative;margin-top:24px}
.map-pane{position:relative}
#map{height:540px;border-radius:var(--radius);border:1px solid var(--line);overflow:hidden;z-index:1}
.map-hint{position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:500;display:none;
  background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:8px 16px;
  font-size:.85rem;font-weight:600;color:var(--text);box-shadow:0 8px 24px -10px rgba(0,0,0,.4);white-space:nowrap}
.discover-layout.view-map .map-hint.show{display:block}
.discover-layout.view-list .map-pane{display:none}
.discover-layout.view-map .cards-panel,
.discover-layout.view-map .no-results{display:none}
.cards-panel{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;align-content:start;
  max-height:560px;overflow-y:auto;padding-left:6px}
.cards-panel.is-empty{display:none}
.cards-panel::-webkit-scrollbar{width:8px}
.cards-panel::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:8px}
.cards-panel::-webkit-scrollbar-track{background:transparent}
.mini-card{background:linear-gradient(160deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:16px;padding:16px;display:flex;gap:14px;align-items:center;cursor:pointer;transition:.25s}
.mini-card:hover{border-color:var(--violet-bright);transform:translateX(-4px)}
.mc-avatar{width:56px;height:56px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1.3rem;color:#fff}
.mc-info{flex:1;min-width:0}
.mc-info h4{font-size:1.05rem;font-weight:700;margin-bottom:3px}
.mc-info .mc-cat{color:var(--violet-soft);font-size:.82rem}
.mc-info .mc-loc{color:var(--text-faint);font-size:.8rem;display:flex;align-items:center;gap:4px;margin-top:4px}
.mc-link{display:inline-flex;align-items:center;gap:4px;margin-top:7px;color:var(--violet);font-size:.82rem;
  font-weight:700;text-decoration:none;transition:gap .18s,color .18s}
.mc-link span{transition:transform .18s}
.mc-link:hover{color:var(--violet-bright)}
.mc-link:hover span{transform:translateX(-3px)}
.cards-group{display:flex;flex-direction:column;gap:12px}
.cards-group+.cards-group{margin-top:6px;padding-top:16px;border-top:1px dashed var(--line)}
.cards-group-title{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;color:var(--text-faint);
  letter-spacing:.01em;padding:0 2px;position:sticky;top:0;background:var(--bg);z-index:2}
.cards-group-title span{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;
  padding:0 6px;border-radius:999px;background:var(--surface-2);color:var(--text);font-size:.72rem;font-weight:700}
.cards-group-hint{color:var(--text-faint);font-size:.85rem;padding:14px 4px;text-align:center}
.mc-views{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-faint);font-size:.75rem}
.mc-views strong{color:var(--text);font-size:1rem}
.no-results{text-align:center;color:var(--text-faint);padding:40px;display:none}
.leaflet-popup-content-wrapper{background:var(--surface-2);color:var(--text);border-radius:14px;border:1px solid var(--line)}
.leaflet-popup-tip{background:var(--surface-2)}
.leaflet-popup-content{margin:14px 16px;font-family:'IRANYekanXFaNum',sans-serif}
.map-pop h4{font-size:1rem;margin-bottom:4px}
.map-pop .mp-cat{color:var(--violet-soft);font-size:.82rem;margin-bottom:8px}
.map-pop a{color:var(--violet-bright);font-size:.85rem;font-weight:600}

/* ===== pricing ===== */
.bill-toggle{display:flex;justify-content:center;gap:14px;align-items:center;margin-bottom:46px}
.bill-toggle span{color:var(--text-dim);font-weight:500}
.bill-toggle span.active{color:var(--text)}
.switch{width:56px;height:30px;background:var(--surface-2);border:1px solid var(--line);border-radius:100px;position:relative;cursor:pointer;transition:.3s}
.switch.on{background:var(--violet)}
.switch::after{content:'';position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:3px;right:3px;transition:.3s}
.switch.on::after{right:calc(100% - 25px)}
.save-badge{background:rgba(74,222,128,.14);color:#4ade80;font-size:.78rem;padding:3px 10px;border-radius:100px;font-weight:600}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price-card{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:36px 30px;display:flex;flex-direction:column;position:relative;transition:transform .3s}
.price-card:hover{transform:translateY(-6px)}
.price-card.featured{border-color:var(--violet-bright);box-shadow:0 24px 60px -24px var(--violet-glow)}
.price-card.featured::before{content:'محبوب‌ترین';position:absolute;top:-13px;right:50%;transform:translateX(50%);
  background:linear-gradient(135deg,var(--violet),var(--violet-bright));color:#fff;font-size:.78rem;font-weight:700;
  padding:5px 18px;border-radius:100px;white-space:nowrap}
.price-name{font-size:1.3rem;font-weight:700;margin-bottom:6px}
.price-desc{color:var(--text-faint);font-size:.9rem;margin-bottom:22px}
.price-amount{font-size:2.6rem;font-weight:800;margin-bottom:4px;display:flex;align-items:baseline;gap:8px;justify-content:flex-start}
.price-amount .unit{font-size:1rem;font-weight:500;color:var(--text-dim)}
.price-period{color:var(--text-faint);font-size:.88rem;margin-bottom:26px}
.price-feats{list-style:none;margin-bottom:30px;flex:1;display:flex;flex-direction:column;gap:13px}
.price-feats li{display:flex;align-items:flex-start;gap:10px;color:var(--text-dim);font-size:.94rem}
.price-feats li svg{width:18px;height:18px;color:var(--violet-bright);flex-shrink:0;margin-top:5px}
.price-feats li.off{color:var(--text-faint);opacity:.5}
.price-feats li.off svg{color:var(--text-faint)}

/* ===== AI band ===== */
.ai-band{background:linear-gradient(135deg,var(--surface-2),var(--bg-2));border:1px solid var(--line);
  border-radius:28px;padding:54px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;overflow:hidden;position:relative}
.ai-band::before{content:'';position:absolute;width:400px;height:400px;border-radius:50%;
  top:-150px;left:-100px;background:radial-gradient(circle,var(--violet-glow),transparent 70%);filter:blur(30px)}
.ai-text{position:relative;z-index:1}
.ai-text h2{font-size:2.2rem;margin-bottom:16px;line-height:1.4}
.ai-text p{color:var(--text-dim);margin-bottom:24px}
.ai-feats{display:flex;flex-direction:column;gap:14px}
.ai-feat{display:flex;gap:14px;align-items:flex-start}
.ai-feat .ic{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-feat .ic svg{width:22px;height:22px;color:var(--violet-bright)}
.ai-feat h4{font-size:1.05rem;margin-bottom:2px}
.ai-feat p{font-size:.9rem;margin:0}
.ai-visual{position:relative;z-index:1;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:24px;font-size:.9rem}
.ai-line{height:10px;border-radius:6px;margin-bottom:12px;background:var(--surface-2)}
.ai-line.violet{background:linear-gradient(90deg,var(--violet),transparent)}
.ai-typing{color:var(--violet-soft);font-size:.85rem;margin-top:8px}

/* ===== affiliate ===== */
.affil{background:linear-gradient(135deg,var(--violet),#5b21b6);border-radius:28px;padding:48px;
  display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;position:relative;overflow:hidden}
.affil::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 20h40M20 0v40' stroke='rgba(255,255,255,.05)' stroke-width='1'/%3E%3C/svg%3E")}
.affil-text{position:relative;z-index:1}
.affil-text h2{font-size:2rem;color:#fff;margin-bottom:10px}
.affil-text p{color:rgba(255,255,255,.85)}
.affil .btn{position:relative;z-index:1;background:#fff;color:var(--violet)}
.affil .btn:hover{transform:translateY(-2px)}

/* ===== blog ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;transition:transform .3s,border-color .3s;cursor:pointer}
.blog-card:hover{transform:translateY(-6px);border-color:rgba(157,92,255,.4)}
.blog-cover{height:180px;position:relative;overflow:hidden}
.blog-cover .tag{position:absolute;top:14px;right:14px;background:rgba(10,6,18,.8);backdrop-filter:blur(8px);
  border:1px solid var(--line);color:var(--violet-soft);font-size:.78rem;padding:4px 12px;border-radius:100px;z-index:1}
.blog-body{padding:22px}
.blog-body h3{font-size:1.15rem;margin-bottom:10px;line-height:1.5}
.blog-body p{color:var(--text-dim);font-size:.9rem;margin-bottom:14px}
.blog-meta{display:flex;align-items:center;gap:8px;color:var(--text-faint);font-size:.82rem}

/* ===== FAQ ===== */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:rgba(157,92,255,.4)}
.faq-q{padding:22px 24px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:1.05rem}
.faq-q .plus{width:24px;height:24px;flex-shrink:0;position:relative;transition:transform .3s}
.faq-q .plus::before,.faq-q .plus::after{content:'';position:absolute;background:var(--violet-bright);border-radius:2px}
.faq-q .plus::before{top:11px;right:4px;width:16px;height:2px}
.faq-q .plus::after{top:4px;right:11px;width:2px;height:16px;transition:transform .3s}
.faq-item.open .plus::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--text-dim)}
.faq-a div{padding:0 24px 22px}

/* ===== final CTA ===== */
.final-cta{text-align:center;background:linear-gradient(165deg,var(--surface-2),var(--bg-2));
  border:1px solid var(--line);border-radius:28px;padding:70px 40px;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;
  top:-200px;right:50%;transform:translateX(50%);background:radial-gradient(circle,var(--violet-glow),transparent 70%);filter:blur(40px)}
.final-cta h2{font-size:2.6rem;margin-bottom:16px;position:relative;z-index:1}
.final-cta p{color:var(--text-dim);font-size:1.15rem;margin-bottom:34px;position:relative;z-index:1}
.final-cta .btn{position:relative;z-index:1}

/* ===== footer ===== */
footer{background:var(--bg-2);border-top:1px solid var(--line);padding:60px 0 30px;margin-top:90px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:46px}
.foot-brand img{height:36px;margin-bottom:16px}
.foot-brand p{color:var(--text-dim);font-size:.92rem;max-width:280px;margin-bottom:20px}
.foot-social{display:flex;gap:12px}
.foot-social a{width:40px;height:40px;border-radius:12px;background:var(--surface);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;transition:.2s}
.foot-social a:hover{border-color:var(--violet-bright);transform:translateY(-3px)}
.foot-social svg{width:20px;height:20px;color:var(--text-dim)}
.foot-col h4{font-size:1rem;margin-bottom:18px;color:var(--text)}
.foot-col a{display:block;color:var(--text-dim);font-size:.92rem;margin-bottom:12px;transition:color .2s}
.foot-col a:hover{color:var(--violet-soft)}
.foot-bottom{border-top:1px solid var(--line);padding-top:28px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.foot-bottom p{color:var(--text-faint);font-size:.88rem}
.enamad-box{background:#fff;border-radius:10px;padding:6px;cursor:pointer}
.enamad-box img{height:60px}

/* ===== reveal animation ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

/* ===== responsive ===== */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero p.lead{margin-inline:auto}
  .hero-actions,.hero-note{justify-content:center}
  .phone-wrap{margin-top:40px}
  .feat-grid,.steps,.price-grid,.blog-grid{grid-template-columns:1fr}
  .steps-line{display:none}
  .cards-panel{grid-template-columns:1fr;max-height:65vh}
  #map{height:460px}
  .ai-band,.affil{grid-template-columns:1fr;text-align:center}
  .ai-feat{text-align:right}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{display:none}
  .nav-cta .btn-ghost{display:none}
  .hamburger{display:flex}
  .hero h1{font-size:2.4rem}
  .sec-head h2{font-size:1.9rem}
  .foot-grid{grid-template-columns:1fr}
  .trust-sep{display:none}
  .ai-band,.affil,.final-cta{padding:34px 22px}
  .final-cta h2{font-size:1.9rem}
}

/* ============================================================
   STARFIELD — animated stars for hero background
   ============================================================ */
.starfield{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.starfield .star{position:absolute;background:#fff;border-radius:50%;opacity:.7;
  animation:twinkle var(--dur,4s) ease-in-out infinite;animation-delay:var(--delay,0s)}
@keyframes twinkle{0%,100%{opacity:.15;transform:scale(.8)}50%{opacity:.95;transform:scale(1.25)}}
.starfield .shoot{position:absolute;width:2px;height:2px;background:linear-gradient(45deg,#fff,transparent);
  border-radius:50%;box-shadow:0 0 6px 1px rgba(255,255,255,.6);
  animation:shoot var(--sdur,6s) linear infinite;animation-delay:var(--sdelay,0s);opacity:0}
.starfield .shoot::after{content:'';position:absolute;top:0;right:0;width:80px;height:1px;
  background:linear-gradient(270deg,rgba(255,255,255,.7),transparent);transform-origin:right center}
@keyframes shoot{0%{transform:translate(0,0);opacity:0}
  8%{opacity:1}20%{opacity:1}30%{transform:translate(-340px,200px);opacity:0}100%{opacity:0}}
.hero .wrap{position:relative;z-index:2}
html[data-theme="light"] .starfield .star{background:var(--violet);opacity:.45}
html[data-theme="light"] .starfield .shoot{background:linear-gradient(45deg,var(--violet),transparent);
  box-shadow:0 0 6px 1px var(--violet-glow)}
html[data-theme="light"] .starfield .shoot::after{background:linear-gradient(270deg,var(--violet-soft),transparent)}

/* ============================================================
   INNER PAGE shell (about, blog, terms, faq pages)
   ============================================================ */
.page-hero{padding:70px 0 40px;position:relative;text-align:center;overflow:hidden;
  border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--bg-2),transparent)}
.page-hero h1{font-size:2.8rem;font-weight:800;letter-spacing:-.01em;margin-bottom:14px;position:relative;z-index:2}
.page-hero p{color:var(--text-dim);font-size:1.1rem;max-width:600px;margin:0 auto;position:relative;z-index:2}
.page-hero .page-badge{display:inline-flex;align-items:center;gap:8px;background:var(--surface);
  border:1px solid var(--line);padding:7px 16px;border-radius:100px;font-size:.85rem;
  color:var(--violet-soft);margin-bottom:20px;position:relative;z-index:2}

/* breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--text-faint);
  flex-wrap:wrap;padding:22px 0}
.breadcrumb a{color:var(--text-dim);transition:color .2s}
.breadcrumb a:hover{color:var(--violet-soft)}
.breadcrumb .sep{color:var(--text-faint);opacity:.5}
.breadcrumb .current{color:var(--violet-soft)}

/* generic content section */
.page-body{padding:60px 0 40px}

/* about page */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;margin-bottom:70px}
.about-grid.rev{direction:ltr}
.about-grid.rev>*{direction:rtl}
.about-text h2{font-size:2rem;margin-bottom:18px;line-height:1.4}
.about-text p{color:var(--text-dim);margin-bottom:16px;font-size:1.02rem}
.about-visual{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:24px;padding:40px;min-height:300px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden}
.about-visual::before{content:'';position:absolute;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,var(--violet-glow),transparent 70%);filter:blur(30px)}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin:60px 0}
.about-stat{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:20px;padding:30px;text-align:center}
.about-stat .num{font-size:2.6rem;font-weight:800;background:linear-gradient(120deg,var(--violet-bright),var(--violet-soft));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}
.about-stat .lbl{color:var(--text-dim);font-size:.95rem;margin-top:6px}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.value-card{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:20px;padding:30px;transition:transform .3s,border-color .3s}
.value-card:hover{transform:translateY(-6px);border-color:rgba(157,92,255,.4)}
.value-card .v-ic{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--violet),var(--violet-bright));
  display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.value-card .v-ic svg{width:26px;height:26px;color:#fff}
.value-card h3{font-size:1.2rem;margin-bottom:10px}
.value-card p{color:var(--text-dim);font-size:.95rem}

/* ============================================================
   BLOG layout (list + sidebar)
   ============================================================ */
.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start}

/* featured post */
.featured-post{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:24px;overflow:hidden;margin-bottom:40px;display:grid;grid-template-columns:1fr 1fr;
  transition:border-color .3s}
.featured-post:hover{border-color:rgba(157,92,255,.4)}
.featured-post .fp-cover{min-height:280px;position:relative}
.featured-post .fp-badge{position:absolute;top:18px;right:18px;background:linear-gradient(135deg,var(--violet),var(--violet-bright));
  color:#fff;font-size:.78rem;font-weight:700;padding:6px 16px;border-radius:100px;z-index:1}
.featured-post .fp-body{padding:36px;display:flex;flex-direction:column;justify-content:center}
.featured-post .fp-cat{color:var(--violet-soft);font-size:.85rem;font-weight:600;margin-bottom:12px}
.featured-post h2{font-size:1.7rem;line-height:1.5;margin-bottom:14px}
.featured-post p{color:var(--text-dim);margin-bottom:20px}
.featured-post .fp-meta{display:flex;align-items:center;gap:14px;color:var(--text-faint);font-size:.85rem}

/* blog list grid */
.blog-list{display:grid;grid-template-columns:1fr 1fr;gap:24px}

/* sidebar */
.blog-sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:100px}
.side-box{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:20px;padding:24px}
.side-box h3{font-size:1.1rem;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.side-box h3 svg{width:18px;height:18px;color:var(--violet-bright)}
.side-search{position:relative}
.side-search input{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:12px;
  padding:13px 44px 13px 14px;color:var(--text);font-family:inherit;font-size:.95rem;transition:border-color .2s}
.side-search input:focus{outline:none;border-color:var(--violet-bright)}
.side-search svg{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-faint)}
.cat-list{list-style:none;display:flex;flex-direction:column;gap:4px}
.cat-list a{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-radius:10px;
  color:var(--text-dim);font-size:.95rem;transition:.2s}
.cat-list a:hover,.cat-list a.active{background:var(--bg);color:var(--violet-soft)}
.cat-list .count{background:var(--surface-2);color:var(--text-faint);font-size:.78rem;padding:2px 9px;border-radius:100px}
.tag-cloud{display:flex;flex-wrap:wrap;gap:9px}
.tag-cloud a{background:var(--bg);border:1px solid var(--line);color:var(--text-dim);font-size:.85rem;
  padding:7px 14px;border-radius:100px;transition:.2s}
.tag-cloud a:hover{border-color:var(--violet-bright);color:var(--violet-soft);transform:translateY(-2px)}
.side-post{display:flex;gap:12px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}
.side-post:last-child{border-bottom:none}
.side-post .sp-thumb{width:60px;height:60px;border-radius:12px;flex-shrink:0}
.side-post .sp-info h4{font-size:.92rem;line-height:1.5;margin-bottom:4px}
.side-post .sp-info .sp-date{color:var(--text-faint);font-size:.78rem}

/* pagination */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:50px}
.pagination a{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-weight:600;transition:.2s}
.pagination a:hover,.pagination a.active{background:linear-gradient(135deg,var(--violet),var(--violet-bright));color:#fff;border-color:transparent}

/* ============================================================
   BLOG DETAIL (article)
   ============================================================ */
.article-hero{height:380px;border-radius:24px;position:relative;overflow:hidden;margin-bottom:40px}
.article-hero .ah-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(10,6,18,.9));
  display:flex;flex-direction:column;justify-content:flex-end;padding:40px}
.article-hero .ah-cat{display:inline-block;background:linear-gradient(135deg,var(--violet),var(--violet-bright));
  color:#fff;font-size:.8rem;font-weight:700;padding:5px 16px;border-radius:100px;margin-bottom:16px;width:fit-content}
.article-hero h1{font-size:2.3rem;line-height:1.5;margin-bottom:18px;max-width:800px}
.article-meta{display:flex;align-items:center;gap:20px;color:var(--text-dim);font-size:.9rem;flex-wrap:wrap}
.article-meta .am-author{display:flex;align-items:center;gap:10px}
.article-meta .am-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--violet-bright))}
.article-content{max-width:760px;font-size:1.08rem;line-height:2.1;color:var(--text-dim)}
.article-content h2{color:var(--text);font-size:1.6rem;margin:38px 0 16px}
.article-content h3{color:var(--text);font-size:1.3rem;margin:30px 0 14px}
.article-content p{margin-bottom:20px}
.article-content ul,.article-content ol{margin:0 22px 22px;display:flex;flex-direction:column;gap:10px}
.article-content blockquote{border-right:3px solid var(--violet-bright);background:var(--surface);
  padding:18px 24px;border-radius:0 14px 14px 0;margin:24px 0;color:var(--text)}
.article-content img{border-radius:16px;margin:24px 0}
.article-tags{display:flex;gap:10px;flex-wrap:wrap;margin:40px 0;padding-top:30px;border-top:1px solid var(--line)}
.article-tags .t-label{color:var(--text-faint);font-size:.9rem;margin-left:4px}
.share-row{display:flex;align-items:center;gap:12px;margin:30px 0}
.share-row span{color:var(--text-dim);font-size:.92rem}
.share-row a{width:40px;height:40px;border-radius:12px;background:var(--surface);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;transition:.2s}
.share-row a:hover{border-color:var(--violet-bright);transform:translateY(-3px)}
.share-row svg{width:18px;height:18px;color:var(--text-dim)}
.author-box{background:linear-gradient(165deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:20px;padding:28px;display:flex;gap:20px;align-items:center;margin:40px 0}
.author-box .ab-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--violet-bright));flex-shrink:0}
.author-box h4{font-size:1.15rem;margin-bottom:6px}
.author-box p{color:var(--text-dim);font-size:.92rem}
.related-posts{margin-top:60px}
.related-posts h3{font-size:1.5rem;margin-bottom:24px}

/* ============================================================
   TERMS / legal page
   ============================================================ */
.legal-layout{display:grid;grid-template-columns:260px 1fr;gap:50px;align-items:start}
.legal-toc{position:sticky;top:100px;background:linear-gradient(165deg,var(--surface),var(--bg-2));
  border:1px solid var(--line);border-radius:20px;padding:24px}
.legal-toc h3{font-size:1rem;margin-bottom:16px;color:var(--text)}
.legal-toc a{display:block;color:var(--text-dim);font-size:.92rem;padding:9px 0;transition:color .2s;border-right:2px solid transparent;padding-right:14px}
.legal-toc a:hover,.legal-toc a.active{color:var(--violet-soft);border-right-color:var(--violet-bright)}
.legal-content h2{font-size:1.5rem;margin:40px 0 16px;scroll-margin-top:100px}
.legal-content h2:first-child{margin-top:0}
.legal-content p{color:var(--text-dim);margin-bottom:16px;line-height:2}
.legal-content ul{margin:0 22px 18px;display:flex;flex-direction:column;gap:10px;color:var(--text-dim)}
.legal-update{color:var(--text-faint);font-size:.9rem;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;padding:14px 18px;margin-bottom:30px;display:inline-block}

/* ============================================================
   FAQ page
   ============================================================ */
.faq-cats{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.faq-cat{background:var(--surface);border:1px solid var(--line);color:var(--text-dim);
  padding:10px 22px;border-radius:100px;font-size:.95rem;font-weight:500;cursor:pointer;transition:.2s}
.faq-cat:hover,.faq-cat.active{background:linear-gradient(135deg,var(--violet),var(--violet-bright));color:#fff;border-color:transparent}
.faq-group{margin-bottom:40px}
.faq-group-title{font-size:1.4rem;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.faq-group-title svg{width:24px;height:24px;color:var(--violet-bright)}

@media(max-width:980px){
  .about-grid,.featured-post,.legal-layout,.blog-layout{grid-template-columns:1fr}
  .blog-list{grid-template-columns:1fr}
  .about-stats{grid-template-columns:1fr 1fr}
  .values-grid{grid-template-columns:1fr}
  .blog-sidebar,.legal-toc{position:static}
  .page-hero h1{font-size:2.1rem}
}
