[data-tooltip]{position:relative; z-index: 2}
/* Modern tooltip system (reusable) */
[data-tooltip]{position:relative}
[data-tooltip]::after{
  content: attr(data-tooltip);
  position:absolute; bottom: calc(100% + 8px); left:50%; transform: translateX(-50%);
  background:#1f2937; color:#fff; padding:8px 10px; border-radius:8px; font-size:11px; font-weight:500;
  box-sizing: border-box;
  display: inline-block; width: max-content; white-space: nowrap; line-height: 1.5;
  direction: rtl; text-align: right;
  opacity:0; visibility:hidden; transition:opacity .15s ease, visibility .15s ease; z-index:9999; pointer-events:none;
}
[data-tooltip]::before{
  content:""; position:absolute; bottom:100%; left:50%; transform:translateX(-50%);
  border:6px solid transparent; border-top-color:#1f2937; opacity:0; visibility:hidden; transition:opacity .15s ease, visibility .15s ease; z-index:9999;
}
[data-tooltip]:hover::after,[data-tooltip]:hover::before{opacity:1; visibility:visible}
@media (max-width:600px){
  [data-tooltip]::after{left:50%; right:auto; transform:translateX(-50%); max-width:none; width:max-content; white-space:nowrap; overflow-wrap:normal; word-break:normal; line-height:1.5}
  [data-tooltip]::before{left:50%; right:auto; transform:translateX(-50%)}
}
:root{
  --font-sans: "Lahzeh", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  --bg:#f6f7fb;
  --panel:#ffffff;
  --ink:#212529;
  --ink-2:#5b6270;
  --brand:#5b43ea;
  --danger:#e03131;
  --purple:#6f42c1;
  --gold:#f59f00;
  --success:#26c281;
  --info:#3b82f6;
  --warning:#ffb020;
  --accent:#f1f2f6;
  --radius:16px;
  --radius-sm:12px;
  --shadow-sm:0 4px 12px rgba(23,23,38,.06);
  --shadow-md:0 8px 24px rgba(23,23,38,.08);
  
  /* Active state variables for consistency */
  --active-bg: rgba(91,67,234,.02);
  --active-border: var(--brand);
  --active-shadow: 0 0 0 1px rgba(91,67,234,.1);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:#fdfcff;
  color:var(--ink);
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Typography normalization */
h1,h2,h3,h4,h5,h6,p,a,li,label,small,strong,em,span{font-family:var(--font-sans)}
button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}
code,kbd,pre,samp{font-family:var(--font-sans)}

.page.page--type{padding-top:8px}
.layout{
  display:grid;
  grid-template-columns: 40% 60%;
  gap:24px;max-width:1200px;margin:0 auto;
  align-items:start; /* prevent equal-height stretching across columns */
}
@media (max-width: 900px){
  .hero-ai{margin:2px 0 6px}
  .hero-ai__container{padding:14px 16px}
  .hero-ai__content{gap:12px}
  .hero-ai__icon .ai-ico{width:24px;height:24px}
  .hero-ai__title{font-size:16px}
  .hero-ai__desc{font-size:13px}
  .layout{ grid-template-columns: 1fr; gap: 12px; }
  .groups, .service{ grid-column: 1; position: static; width: 100%; max-width: 100%; min-width: 0; overflow-x: hidden; }
}

/* Top categories full-width row */
.top-cats{max-width:1200px;margin:0 auto 20px}
.top-cats__list{padding: 6px 0 6px 0; display:grid;grid-template-columns:repeat(3,1fr);gap:16px;overflow:hidden}
.top-cat{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--accent);background:#fff;border-radius:var(--radius-sm);padding:16px 18px;cursor:pointer;transition:all .3s ease;text-decoration:none;color:inherit;position:relative;overflow:hidden}
.top-cat::before{content:none}
.top-cat[aria-current="true"], .top-cat:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.top-cat.active{border-color: var(--active-border);background: var(--active-bg);box-shadow: var(--active-shadow)}
.top-cat .title{font-weight:600;font-size:15px;color:var(--ink)}
.top-cat__content{display:flex;align-items:center;gap:12px}
.icon-badge{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg, rgba(91,67,234,.08), rgba(91,67,234,.12));font-size:16px;color:var(--brand);font-weight:600;transition:all .3s ease;box-shadow:0 2px 6px rgba(91,67,234,.08)}
.icon-badge.lg{width:40px;height:40px;font-size:18px}
.icon-badge:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(91,67,234,.12)}
/* flatter icon badge inside groups */
.groups .icon-badge{background:#f3f4f8;border:1px solid var(--accent);box-shadow:none;transition:none;width:28px;height:28px;border-radius:10px;font-size:14px}
.groups .icon-badge:hover{transform:none;box-shadow:none}

/* AI hero banner (minimal, flat) */
.hero-ai{background:#fff;border-top:1px solid var(--accent);border-bottom:1px solid var(--accent);margin:4px 0 8px}
.hero-ai__container{max-width:1200px;margin:0 auto;padding:16px 24px}
.hero-ai__content{display:flex;align-items:center;gap:14px}
.hero-ai__icon{font-size:0}
.hero-ai__icon .ai-ico{width:28px;height:28px;fill:var(--brand)}
.hero-ai__title{margin:0 0 2px;font-weight:800;font-size:18px;line-height:1.25}
.hero-ai__desc{margin:0;color:var(--ink-2);line-height:1.6}

/* Standardized spacing for the text block inside hero */
.her-ai-left{display:flex;flex-direction:column;gap:15px}

/* Breadcrumb (pill-style, compact spacing) */
.breadcrumb{background:transparent;padding:8px 0;margin:4px 0;position:relative}
.breadcrumb::before{content:none}
.breadcrumb-container{max-width:1200px;margin:0 auto;padding:0 24px}
.breadcrumb-list{display:flex;align-items:center;gap:10px;margin:0;padding:0;list-style:none;flex-wrap:wrap}
.breadcrumb-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-2);position:relative}
.breadcrumb-item:not(:last-child)::after{content:"›";color:var(--ink-3);font-size:14px;font-weight:700;margin:0 4px}
.breadcrumb-link{color:var(--ink);text-decoration:none;font-weight:600;transition:color .2s ease, background-color .2s ease, border-color .2s ease;padding:6px 10px;border-radius:10px;background:#fff;border:1px solid var(--accent)}
.breadcrumb-link::before{content:none}
.breadcrumb-link:hover{color:var(--ink);text-decoration:none;background:rgba(91,67,234,.04);border-color:rgba(91,67,234,.2)}
.breadcrumb-link span{position:relative;z-index:1}
.breadcrumb-current{color:var(--ink);font-weight:700;padding:6px 10px;border-radius:10px;background:#fff;border:1px solid var(--accent);box-shadow:none}

/* Right column - main categories */
.main-cats{
  background:var(--panel);
  border-radius:var(--radius);
  padding:20px;
  height:max-content;
  border:1px solid var(--accent);
}
.main-cats__header{font-weight:700;margin-bottom:16px;font-size:16px;color:var(--ink);display:flex;align-items:center;gap:8px}
.main-cats__header::before{content:"";width:4px;height:16px;background:var(--brand);border-radius:2px}
.main-cats__list{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.main-cats__item{
  display:flex;align-items:center;justify-content:space-between;
  border:1px solid var(--accent);
  border-radius:var(--radius-sm);
  padding:14px 16px;
  background:#fff;
  cursor:pointer;
  transition:all .2s ease;
  position:relative;
}
.main-cats__item[aria-current="true"], .main-cats__item:hover{
  border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(91,67,234,.08);
  transform:translateY(-1px);
}
.main-cats__item .title{font-weight:600;font-size:14px;color:var(--ink)}

/* Columns */
.service{background:var(--panel);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all .3s ease; max-width: 100%;}
.groups{grid-column:1; grid-row:1; align-self:start}
.service{grid-column:2; grid-row:1; align-self:start}
.service.service--slider{padding:0;border:none;box-shadow:none;background:transparent}
.comments-block{margin:16px 0}
.comments-section{margin:12px 0 16px;padding:10px 12px;border:1px solid var(--accent);border-radius:14px;background:#fbfbfe}
.comments-label{font-weight:700;font-size:14px;color:var(--ink);margin-bottom:6px}
.comments-note{display:block;color:var(--ink-2);margin:8px 0 6px}
.comments-input{width:100%;min-height:96px;resize:vertical;border:0;border-radius:10px;padding:10px 12px;font:inherit;background:transparent;transition:border-color .2s ease, box-shadow .2s ease; direction: rtl; text-align: right}
.comments-input::placeholder{color:var(--ink-2)}
.comments-input:focus{outline:none;box-shadow:0 0 0 3px rgba(91,67,234,.1)}
.comments-count{margin-top:8px;font-size:12px;color:var(--ink-2)}
.comments-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px}
.comments-meta .comments-note{margin:0}
.comments-meta .comments-count{margin:0}
.groups{position:sticky; top:16px; height:max-content; box-shadow:none; padding:20px;max-width:100%; overflow-x:hidden}
.groups__search h3{margin:0 0 12px;font-weight:700;font-size:16px;color:var(--ink);display:flex;align-items:center;gap:8px}
.groups__search h3::before{content:"";width:3px;height:16px;background:var(--brand);border-radius:2px}
.groups__search{margin-bottom:20px}
.searchbar{position:relative;margin:12px 0 16px}
.searchbar input{width:100%;border:1px solid var(--accent);background:#fff;border-radius:var(--radius-sm);padding:12px 40px 12px 14px;font:inherit;transition:all .3s ease;font-size:14px}
/* Search icon */
.searchbar::before{content:"";position:absolute;top:50%;right:12px;transform:translateY(-50%);width:18px;height:18px;pointer-events:none;opacity:.5;background:currentColor;mask:url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\"><path fill=\"%23000\" d=\"M15.5 14h-.79l-.28-.27A6.471 6.471 0 0 0 16 9.5 6.5 6.5 0 1 0 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19 15.5 14zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z\"/></svg>') center / contain no-repeat}
.searchbar input::placeholder{color:var(--ink-2);font-size:14px}
.searchbar input:hover{border-color:var(--brand);background:#fff}
.searchbar input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(91,67,234,.1);outline:none;background:#fff}
.group{border:none;border-radius:var(--radius-sm);overflow:visible;margin-bottom:10px;transition:all .3s ease;box-shadow:none;border:1px solid var(--accent)}
.group__header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;font-weight:600;background:#fff;border:0;border-radius:var(--radius-sm);width:100%;transition:all .2s ease;font-size:14px;color:var(--ink)}
.group__header{position:relative;z-index:1}
.group__header:hover{
  background:rgba(91,67,234,.04);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.group__header.active{
  background:#fff;
  border-bottom: 1px solid var(--accent);
  box-shadow:none;
}
.group__header:focus-visible{outline:3px solid rgba(91,67,234,.25);outline-offset:2px}
.group__title{display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .3s ease;text-decoration:none;color:inherit}
.group__title:hover{opacity:.8;text-decoration:none}
/* Better keyboard focus for title link */
.group__title:focus-visible{outline:3px solid rgba(91,67,234,.25);outline-offset:2px;border-radius:10px}
/* Complementary title in type page */
.complementary-title{font-weight:800;font-size:14px;color:var(--ink);margin:12px 0 8px}
/* Standard chevron button styles */
.chevron-btn{transition:transform .3s ease;color:var(--brand);opacity:.8;cursor:pointer;padding:4px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;font-size:inherit}
.chevron-btn:hover{background:#eef1ff;opacity:1}
.chevron-btn:focus{outline:2px solid rgba(91,67,234,.25);outline-offset:2px}
.chevron-btn:focus-visible{outline:2px solid rgba(91,67,234,.25);outline-offset:2px}
.chevron-btn .chev-ico{width:16px;height:16px;display:block}
.chevron-btn .chev-ico path{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
/* Larger hit area without visual bulk */
.chevron-btn,.group__chevron,.category-line__chevron{min-width:36px;min-height:36px}

/* Group chevron specific */
.group__chevron{transition:transform .3s ease;color:var(--brand);opacity:.8;cursor:pointer;padding:4px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;font-size:inherit}
.group__chevron .chev-ico{width:18px;height:18px;display:block}
.group__body{padding:12px 14px;display:none}
.group.open .group__body{display:block;animation:none}
.group.open .group__chevron{transform:rotate(180deg)}
.group.open{
  border: none;
  background:#fff;
  transition: background-color .2s ease;
}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:8px 12px;border-radius:999px;border:1px solid var(--accent);background:#fff;font-size:14px}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Smooth transitions for content changes */
.groups, .service {
  animation: fadeIn .3s ease;
}

/* Loading animation */
.loader-container {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  min-height: 200px;
}

.loader {
  position: relative;
  width: 40px;
  height: 40px;
}

.loader::before,
.loader::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  animation: loader-pulse 1.5s ease-in-out infinite;
}

.loader::before {
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, var(--brand), rgba(91,67,234,.6));
  animation-delay: 0s;
}

.loader::after {
  width: 24px;
  height: 24px;
  background: rgba(91,67,234,.3);
  top: 8px;
  left: 8px;
  animation-delay: 0.3s;
}

@keyframes loader-pulse {
  0%, 100% {
    transform: scale(0.8);
    opacity: 0.5;
  }
  50% {
    transform: scale(1);
    opacity: 1;
  }
}

/* Loading text */
.loader-text {
  margin-top: 16px;
  color: var(--ink-2);
  font-size: 14px;
  font-weight: 500;
  text-align: center;
}

/* Fade out animation for loader */
.loader-container.fade-out {
  animation: fadeOut .3s ease forwards;
}

@keyframes fadeOut {
  from { opacity: 1; }
  to { opacity: 0; }
}

/* No animation needed - just static background */

/* Unified line style for categories list */
.category-lines{display:flex;flex-direction:column;gap:10px}
.category-line{border:1px solid var(--accent);border-radius:var(--radius-sm);padding:12px 14px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .2s ease;position:relative}
.category-line.active{
  border-color: var(--active-border);
  background: var(--active-bg);
  box-shadow: var(--active-shadow);
}
.category-line::before{content:none}
.category-line__content{display:flex;align-items:center;gap:10px;position:static;text-decoration:none;color:inherit;cursor:pointer;font-size:14px;font-weight:500}
.category-line:hover{border-color: var(--brand);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.category-line.open{
  border-color: var(--brand);
  background: rgba(91, 67, 234, 0.02);
  transition: all 0.3s ease;
}
/* Chevron emphasis when open */
.group.open .group__chevron{background:#eef1ff;color:var(--brand)}
.category-line.open .category-line__chevron{background:#eef1ff;color:var(--brand)}
.category-line:focus-visible{outline:3px solid rgba(91,67,234,.25);outline-offset:2px}
.category-line__chevron{transition:transform .3s ease;opacity:.8;color:var(--brand);position:relative;z-index:1;padding:4px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;font-size:inherit}
.category-line__chevron .chev-ico{width:16px;height:16px;display:block}
.category-line.open .category-line__chevron{transform:rotate(180deg);opacity:.8}
/* Subtle left accent bar for open state */
.category-line{position:relative}
.category-line.open::before{content:"";position:absolute;inset:auto auto 0 0;width:3px;height:100%;background:var(--brand);border-top-left-radius:10px;border-bottom-left-radius:10px;opacity:.85}
/* Better keyboard focus for line content */
.category-line__content:focus-visible{outline:3px solid rgba(91,67,234,.25);outline-offset:2px;border-radius:8px}
.accordion__body{margin:8px 0 12px;padding:16px;background:rgba(91,67,234,.02);animation:fadeInUp .3s ease}

/* Respect reduced motion preferences */
@media (prefers-reduced-motion: reduce){
  .groups *{transition:none !important}
  .groups .accordion__body{animation:none !important}
  .groups .group__chevron,.groups .category-line__chevron{transition:none !important}
}


.group{
  border: none;
  border-radius: 6px;
  margin-bottom: 8px;
  overflow: hidden;
}
.group:hover{box-shadow:none}
.group.open{border-color: var(--accent)}

.group__header{
  border-radius:0;
  backdrop-filter:none;
  padding: 12px 16px;
  border-bottom: 1px solid var(--accent);
}

.category-line{
  border: none;
  background:#fff;
  border-radius: 15px;
  margin-bottom: 6px;
  padding: 10px 14px;
}
.category-line:hover{
  background: rgba(91, 67, 234, 0.04);
  transition: background-color .2s ease, border-color .2s ease;
}
.category-line.open{border-color: var(--brand)}
.category-line.open::before{display: none}
/* Active state: minimal & flat */
.category-line.active{
  border:1px solid var(--accent);
  background:#fff;
  box-shadow:none;
}

/* Open + active remains minimal */
.category-line.open.active{border-color: var(--accent);background:#fff}

/* Minimal chevron styling (no pill background) */
.category-line .category-line__chevron{background:none;color:inherit}
.category-line.open .category-line__chevron,
.category-line.active .category-line__chevron{background:none;color:var(--brand)}

/* Softer focus for accessibility without clutter */
.category-line:focus-visible{outline:2px solid rgba(91,67,234,.18);outline-offset:2px}

.accordion__body{
  background:#fff;
  border:1px solid rgb(176 163 255 / 10%);
  box-shadow:none;
  margin: 0;
  padding: 12px 16px;
  border-radius: 15px;
}

/* Service item polish */
.services-item{
  border: none;
  background:#fff;
  border-radius: 4px;
  margin-bottom: 4px;
  padding: 8px 12px;
}
.services-item .service-icon{background:rgba(91,67,234,.06);color:var(--brand)}
.services-item .service-price{
  background: rgba(91,67,234,.06);
  border: 1px solid rgba(91,67,234,.12);
  border-radius: 4px;
  padding: 3px 6px;
  font-size: 11px;
}
.services-item:hover{
  background: rgba(91, 67, 234, 0.04);
  transform: translateY(-1px);
  transition: all 0.3s ease;
}
.services-item.active{
  border: none;
  background: rgba(91, 67, 234, 0.04);
  transition: all 0.3s ease;
}

/* Searchbar glass look override */
.searchbar:before{content:none}
.searchbar input{
  background:rgba(91,67,234,.02);
  border:1px solid rgba(91,67,234,.15);
  box-shadow:none;
  padding: 10px 14px;
  border-radius: 15px;
}
.searchbar input:hover{
  border-color:rgba(91,67,234,.3);
  transform: translateY(-1px);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.searchbar input:focus{
  border-color:rgba(91,67,234,.5);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(91,67,234,.15);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.service-card{
  border-radius: 15px;
  transition: all .3s ease;
  position: relative;
  overflow: visible;
  padding: 25px;
  background: #fff;
}

.service-card::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(91,67,234,.3), transparent);
  opacity: 0;
  transition: opacity .3s ease;
}

.service-card:hover{
  box-shadow: 0 8px 40px rgba(91,67,234,.15);
  border-color: rgba(91,67,234,.3);
  transform: translateY(-2px);
}

.service-card:hover::before{
  opacity: 1;
}
.service-header{
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 24px;
  overflow: visible;
  position: relative;
}

.service-header .header-top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
}

.service-header .header-left{
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.service-header .name{
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
  margin: 0;
  line-height: 1.3;
  flex: 1;
  min-width: 0;
}

.service-header .flag{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 45px;
  height: 45px;
  border-radius: 10px;
  background: rgba(91,67,234,.08);
  color: var(--brand);
  flex-shrink: 0;
}

.service-header .flag .ico{
  width: 18px;
  height: 18px;
  fill: currentColor;
}

/* Desktop: larger service icon inside flag */
@media (min-width: 901px){
  .service-header .flag{width:56px;height:56px}
  .service-header .flag .ico{width:28px;height:28px}
}

.service-header .header-right{
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.service-header .rating{
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  background: transparent;
  padding: 0;
  border-radius: 0;
  border: 0;
  position: relative;
  cursor: pointer;
  animation: none;
  text-align: right;
  color: var(--ink);
}

@keyframes ratingPulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(91, 67, 234, 0.4);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(91, 67, 234, 0);
  }
}

.service-header .rating-top{
  display: flex;
  align-items: center;
  gap: 4px;
  justify-content: flex-end;
  width: 100%;
}

.service-header .stars{
  display: flex;
  gap: 2px;
}

.service-header .star{color:#f59e0b;font-size:12px}

.service-header .rating-score{color:var(--ink);font-weight:700;margin:0}

  .service-header .reviews-count{
  color: var(--ink-2);
  font-size: 10px;
  font-weight: 500;
  margin: 0;
  white-space: nowrap;
  text-align: left;
  width: 100%;
}

.service-header .header-bottom{
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 4px;
  overflow: visible;
  position: relative;
}
/* Time badge at left end of labels row */
.service-header .time-badge{
  margin-inline-start: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--ink-2);
  font-weight: 600;
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--accent);
}
.service-header .time-badge .ico{display:inline-flex;width:12px;height:12px;color:#6b7280}

.service-header .status-badge{
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  position: relative;
  cursor: help;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.service-header .status-badge:hover{
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.service-header .status-badge.online{
  background: rgba(34, 197, 94, 0.1);
  color: #22c55e;
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.service-header .status-badge.guarantee{
  background: rgba(91, 67, 234, 0.1);
  color: var(--brand);
  border: 1px solid rgba(91, 67, 234, 0.2);
}

.service-header .status-badge.success-rate{
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
  border: 1px solid rgba(16, 185, 129, 0.2);
}

.service-header .status-badge.orders{
  background: rgba(245, 158, 11, 0.1);
  color: #f59e0b;
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.service-header .status-icon{
  width: 11px;
  height: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Legacy tooltip removed in favor of modern, reusable tooltip system */

/* Mobile-safe tooltip positioning to avoid clipping near edges */
@media (max-width: 600px){
  .service-header .tooltip{
    right: 0;
    left: auto;
    transform: none;
    max-width: calc(100vw - 24px);
    white-space: normal;
    word-break: break-word;
    line-height: 1.6;
  }
  .service-header .tooltip::after{
    left: auto;
    right: 12px;
    transform: none;
  }
}

.service-header .status-badge:hover .tooltip,
.service-header .rating:hover .tooltip{
  opacity: 1;
  visibility: visible;
}
.service-card .name{letter-spacing:.2px}
.service-card hr{border:0;border-top:1px solid var(--accent);margin:20px 0}
.bullets{margin:12px 0 16px;padding:22px;list-style:none;display:grid;gap:10px;background:#fdfcff;border-radius:22px}
.bullets li{color:var(--ink-2);margin:0;display:flex;align-items:flex-start;gap:10px;line-height:1.6}
.bullets li::before{content:"";width:6px;height:6px;border-radius:999px;background:var(--ink-3);opacity:.85;flex:0 0 6px;position:relative;top:6px}
.services-list{display:flex;flex-direction:column;gap:8px}
.services-item{border:1px solid var(--accent);border-radius:var(--radius-sm);padding:12px 14px;background:#fff;cursor:pointer;transition:all .2s ease;position:relative;text-decoration:none;color:inherit;display:flex;align-items:center;gap:10px;text-decoration:none}
.services-item::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:var(--radius-sm);background:rgba(91,67,234,.02);opacity:0;transition:opacity .2s ease;pointer-events:none}
.services-item:hover::before{opacity:1}
.services-item:hover{border-color:var(--brand);background:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.services-item.active{
  border: 1px solid var(--accent);
  background: #fbfbff;
  position: relative;
  box-shadow: 0px 1px 7px -2px rgb(104 52 253 / 20%);
}
.services-item.active::after{
  content: "";
  position: absolute;
  top: 50%;
  left: 12px;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand);
  border: 1px solid #fff;
}
.services-item:focus-visible{outline:2px solid rgba(91,67,234,.25);outline-offset:2px}
.services-item:focus{outline:2px solid rgba(91,67,234,.25);outline-offset:2px}
.services-item .service-content{
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  order: 2;
}
.services-item .service-icon{
  order: 1;
  flex-shrink: 0;
}
.services-item .service-name{
  font-weight: 500;
  color: var(--ink);
  line-height: 2;
  word-wrap: break-word;
  transition: color .2s ease;
}
.services-item:hover .service-name{
  color: var(--brand);
}
.services-item .service-price{
  color: var(--brand);
  font-weight: 600;
  font-size: 12px;
  white-space: nowrap;
  background: rgba(91,67,234,.08);
  border: 1px solid rgba(91,67,234,.15);
  border-radius: 6px;
  padding: 4px 8px;
  display: inline-block;
  align-self: flex-start;
}
.services-item div{position:relative;z-index:1}
.services-item small{position:relative;z-index:1;color:var(--brand);font-weight:600}
.services-item .service-icon{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 6px;
  background: rgba(91,67,234,.08);
  color: var(--brand);
  flex-shrink: 0;
  transition: all .2s ease;
  order: 1;
}
.services-item:hover .service-icon{
  background: rgba(91,67,234,.12);
  transform: scale(1.05);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.service-card .name{
  font-weight: 600;
  margin: 0 0 16px;
  font-size: 18px;
  color: var(--ink);
  position: relative;
}


.service-card .sub{color:var(--ink-2);font-size:13px;margin:0 0 16px}

/* Service card sections - minimal purchase bar */
.purchase-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:#fdfcff;
  border-radius:14px;
  padding:12px 14px;
  margin:16px 0 20px;
}
.purchase-bar .pb-qty,
.purchase-bar .pb-price{
  display:flex;
  align-items:center;
  gap:10px;
}
.purchase-bar .pb-label{
  font-weight:700;
  color:var(--ink-2);
  font-size:14px;
}
.purchase-bar select{
  border:1px solid var(--accent);
  background:#fff;
  border-radius:10px;
  padding:8px 12px;
  min-width:120px;
}
/* Remove focus styling per user preference for ultra-minimal look */
.purchase-bar select:focus{outline:none;border-color:var(--accent)}
.purchase-bar .pb-value{
  font-weight:800;
  color:var(--brand);
  font-size:18px;
}
.badges{display:none}
.input-row{display:flex;align-items:center;gap:8px;border:1px solid var(--accent);border-radius:14px;padding:10px 12px;background:#fbfbfe;margin:16px 0;position:relative;transition:border-color .2s ease,box-shadow .2s ease}
.input-row::before{content:"🔗";position:absolute;right:10px;opacity:.6}
.input-row input{padding-right:28px}
.input-row:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px rgba(91,67,234,.08)}
.input-row:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px rgba(91,67,234,.1)}
.input-row input{flex:1;border:0;background:transparent;outline:none;font:inherit}
.order-row{display:flex;align-items:center;gap:12px;margin-top:16px}
.order-row .btn{flex:1;text-align:center}
.btn.btn-xl{padding:14px 18px;font-size:16px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;gap:10px;position:relative;overflow:hidden}
.btn.btn-xl::after{content:"";position:absolute;inset:0;background:linear-gradient(45deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.28) 50%, rgba(255,255,255,0) 100%);background-size:200% 100%;background-repeat:no-repeat;background-position:200% 0;pointer-events:none;animation:btn-shimmer 2.6s ease-in-out infinite}
@keyframes btn-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@media (prefers-reduced-motion: reduce){.btn.btn-xl::after{animation:none;display:none}}
.btn.btn-xl .btn-ico{width:18px;height:18px;display:inline-block}
.btn.btn-xl:focus{outline:0;box-shadow:0 0 0 3px rgba(91,67,234,.15)}
.helper{display:none}
.options-row{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}
.option-btn{border:1px solid var(--accent);background:#fff;border-radius:999px;padding:8px 12px;cursor:pointer;font-size:14px}
.option-btn.active{
  border-color: var(--active-border);
  background: var(--active-bg);
  box-shadow: var(--active-shadow);
}
.total-row{display:none}
.total{display:none}
.warning-box{display:none}

/* Quantity badge next to submit */
.count-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(91,67,234,.15);background:rgba(91,67,234,.08);border-radius:12px;padding:8px 12px;font-size:13px;color:var(--brand);font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px rgba(91,67,234,.1)}
.count-badge::before{content:"#";opacity:.7;font-weight:700}
.count-badge:hover{background:rgba(91,67,234,.12);border-color:rgba(91,67,234,.25);transform:translateY(-1px);box-shadow:0 4px 12px rgba(91,67,234,.15)}

/* Options detail sections (chips grid) */
.options-panel{margin:16px 0 12px}
.option-section{margin:12px 0}
.option-title{font-weight:700;margin:0 0 6px}
.option-note{color:#e03131;font-weight:700;font-size:13px;margin:0 0 8px}
.chips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.chip-btn{border:1px solid var(--accent);background:#fff;border-radius:14px;padding:12px;text-align:center;cursor:pointer}
.chip-btn.active{
  border-color: var(--active-border);
  background: var(--active-bg);
  box-shadow: var(--active-shadow);
}

/* Minimal sort bar on type page */
.filters-bar{display:flex;gap:6px;align-items:center;margin:6px 0 10px;flex-wrap:nowrap;overflow:visible}
.filters-bar::-webkit-scrollbar{display:none}
.filters-bar .chip-btn{padding:6px 10px;border-radius:12px;display:inline-flex;align-items:center;gap:6px;min-height:32px;flex:0 0 auto}
.filters-bar .chip-btn .ico{display:inline-flex;width:14px;height:14px;line-height:0}
.filters-bar .chip-btn .label{line-height:1;font-weight:600;font-size:12px}
.filters-bar .chip-btn.active{border-color:var(--brand);background:rgba(91,67,234,.08)}
.filters-bar .chip-sep{width:1px;height:22px;background:var(--accent);opacity:.6;border-radius:1px;margin:0 4px;align-self:center}
.filters-bar .chip-sep::before{content:"";display:block;width:1px;height:100%;background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.45), rgba(0,0,0,0));opacity:.1}
.filters-bar .chip-btn[data-sort="instant"]{background:#fff7cc;border-color:rgba(234,179,8,.35)}
.filters-bar .chip-btn[data-sort="instant"] .ico{color:#ca8a04}
.filters-bar .chip-btn[data-sort="instant"].active{background:#fde68a;border-color:rgba(234,179,8,.55)}

/* Filters section wrapper within groups column — header-like */
.filters-section{
  margin:0 0 12px;
  padding:8px 0 12px;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  display:flex;
  flex-direction:column;
  gap:8px;
  position:relative;
}
.filters-section::after{
  content:"";
  display:block;
  height:1px;
  background: var(--accent);
  -webkit-mask: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  mask: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  margin-top:4px;
}
.filters-section::before{
  content:"فیلترها";
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:800;
  font-size:14px;
  color:var(--ink);
}
/* Ensure inner bar sits nicely inside the header */
.filters-section .filters-bar{margin:0}

/* Service tiny labels (e.g., آنی) inside accordion items */
.service-label{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:700;line-height:1;white-space:nowrap;align-self:flex-start;width:fit-content}
.service-label.instant{border:1px solid rgba(234,179,8,.45);color:#111827;background:#fde68a}

/* Pin label at top-left of each services item */
.services-item .service-label{position:absolute;top:8px;left:10px;z-index:1}

/* Instant badge in service header */
.service-header .status-badge.instant{background:#fde68a;color:#111827;border:1px solid rgba(234,179,8,.45)}

.btn{
  border:1px solid var(--brand);
  color:#fff;
  background:var(--brand);
  padding:10px 14px;
  border-radius:10px;
  cursor:pointer;transition:transform .05s ease,box-shadow .2s ease;
  box-shadow: 0 0 0 4px #3d22ff0f;
}
.btn.secondary{
  background:#fff;color:var(--brand);
}
.divider{height:1px;background:var(--accent);margin:12px 0}
.btn:hover{box-shadow:0 8px 24px rgba(91,67,234,.2)}
.btn:active{transform:translateY(1px)}

/* Show-more button */
.show-more{display:flex;align-items:center;gap:10px;margin-top:16px;padding:12px 0}
.show-more button{all:unset;cursor:pointer;color:var(--brand);font-weight:600;transition:all .3s ease}
.show-more .load-more{width:100%;text-align:center;border:1px solid rgba(91,67,234,.15);background:rgba(91,67,234,.02);border-radius:16px;padding:12px 16px;transition:all .3s ease;font-weight:600}
.show-more .load-more:hover{background:rgba(91,67,234,.06);border-color:rgba(91,67,234,.25);box-shadow:0 4px 12px rgba(91,67,234,.08);transform:translateY(-1px)}
.show-more .count{min-width:40px;text-align:center;color:var(--brand);font-weight:700;background:rgba(91,67,234,.1);border-radius:12px;padding:6px 10px;font-size:14px}

/* Mobile: right column becomes a horizontal scroll list */
@media (max-width: 900px){
  .layout{grid-template-columns:1fr;gap:16px}
  .groups, .service{grid-column: 1 / -1; grid-row: auto; width: 100%; position:static}
  .top-cats__list{display:flex;gap:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scrollbar-width:none}
  .top-cats__list::-webkit-scrollbar{display:none}
  .top-cat{min-width:200px;scroll-snap-align:start;flex-shrink:0}
  .breadcrumb{padding:6px 0;margin:2px 0}
  .breadcrumb-container{padding:0 16px}
  .breadcrumb-list{gap:8px}
  .breadcrumb-item{font-size:12px;gap:8px}
  .breadcrumb-item::after{font-size:13px;margin:0 2px}
  .breadcrumb-link{padding:6px 8px;border-radius:10px}
  .breadcrumb-current{padding:6px 8px;border-radius:10px}
  .main-cats{
    padding:0 0 12px 0;
    background:transparent;
    border:none;
  }
  .main-cats__header{padding:0 12px;margin-bottom:12px}
  .main-cats__list{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    display:flex;
    flex-direction:row;
    gap:10px;
    padding:0 12px;
    scroll-snap-type:x mandatory;
  }
  .main-cats__item{min-width:180px;scroll-snap-align:start;flex-shrink:0}
  /* Soft padding for groups on mobile so items don't touch edges */
  .groups{padding:16px;border-radius:var(--radius-sm)}
  .group{margin-bottom:10px}
  .group__header{padding:14px 16px}
  .group__body{padding:14px 16px}
  .category-line{padding:12px 14px}
  .accordion__body{padding:14px}
  .services-item{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px}
  .services-item .service-content{
    gap: 4px;
  }
  .services-item .service-name{
    font-size: 14px;
  }
  .services-item .service-price{
    font-size: 11px;
    padding: 3px 6px;
  }
  .filters-bar{gap:8px;margin:6px 0 10px}
  .filters-bar .chip-btn{padding:10px 12px;min-height:38px}
  /* Larger touch targets on mobile */
  .chevron-btn,.group__chevron,.category-line__chevron{min-width:44px;min-height:44px}
  /* Mobile minimal adjustments */
  .groups{padding: 16px}
  .group__header{padding: 12px 16px}
  .category-line{padding: 10px 14px}
  .services-item{padding: 8px 12px}
  
  /* Mobile purchase-bar */
  .purchase-bar{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:12px 14px;
  }
  .purchase-bar .pb-qty,
  .purchase-bar .pb-price{
    justify-content:space-between;
  }
  .purchase-bar select{width:100%}
  
  /* Mobile service-card improvements */
  .service-card{
    padding: 24px 20px;
    border-radius: 24px;
  }
  
  .service-header{
    padding: 14px 16px;
    margin-bottom: 20px;
  }
  
  .service-header .header-top{
    gap: 12px;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
  
  .service-header .header-left{
    width: auto;
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
  }
  
  .service-header .name{
    font-size: 16px;
    width: 70%;
    flex: 1;
  }
  
  .service-header .rating{
    padding: 0;
    font-size: 12px;
    gap: 6px;
    width: auto;
    flex-shrink: 0;
    min-width: unset;
  }
  
  .service-header .header-bottom{
    gap: 12px;
    width: 100%;
  }
  
  .service-header .status-badge{
    padding: 4px 8px;
    font-size: 11px;
  }
}

.site-header{background:#fff;box-shadow:0 2px 12px rgba(23,23,38,.04);position:sticky;top:0;z-index:50}
.header-container{max-width:1200px;margin:0 auto;padding:10px 24px}
.header-row{display:flex;align-items:center;gap:16px;justify-content:space-between}
.header-brand{display:flex;align-items:center;gap:10px;color:inherit;text-decoration:none}
.header-logo{width:32px;height:32px;border-radius:8px}
.header-title{font-weight:800}
.header-nav{display:flex;gap:10px}
.header-nav a{text-decoration:none;color:inherit}
.btn-head{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--accent);border-radius:12px;padding:8px 12px}
.btn-head .ico{width:18px;height:18px;fill:currentColor}
.btn-head .label{font-weight:700}
.btn-head.primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn-head.secondary{background:#fff}

/* User menu */
.user-menu{position:relative}
.user-toggle{display:inline-flex;align-items:center;gap:8px}
.user-brief{display:flex;align-items:center;gap:10px}
.user-avatar{width:24px;height:24px;border-radius:50%;background:#eceefe;display:inline-flex;align-items:center;justify-content:center;color:var(--brand);font-size:12px;font-weight:800}
.user-avatar svg{width:14px;height:14px;fill:var(--brand)}
.user-meta{display:flex;align-items:center;gap:6px}
.user-phone{font-weight:800;font-size:14px}
.user-caret{font-size:10px;color:var(--brand)}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:280px;background:#fff;border:1px solid var(--accent);border-radius:16px;box-shadow:0 16px 36px rgba(23,23,38,.14);padding:12px;z-index:60}
.user-dropdown{opacity:0;transform:translateY(6px);transition:opacity .16s ease, transform .16s ease}
.user-dropdown.open{opacity:1;transform:translateY(0)}
.user-backdrop{display:none}
.user-dropdown .ud-section-title{margin:4px 10px 6px;font-size:12px;color:var(--ink-2);font-weight:700}
.ud-head{display:flex;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid var(--accent)}
.ud-head .user-avatar{width:36px;height:36px;border-radius:12px}
.ud-head .user-avatar svg{width:18px;height:18px;fill:var(--brand)}
.ud-head .user-id{font-size:12px;color:var(--ink-2)}
.ud-wallet{display:flex;align-items:center;justify-content:space-between;gap:10px;background:linear-gradient(135deg, rgba(91,67,234,.06), rgba(91,67,234,.1));border:1px solid rgba(91,67,234,.2);border-radius:14px;padding:12px;margin:12px}
.ud-wallet .bal{font-weight:800;color:var(--brand)}
.ud-wallet a{font-weight:700;color:#fff;text-decoration:none;background:var(--brand);border:1px solid var(--brand);padding:6px 10px;border-radius:10px}
.ud-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column}
.ud-item a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:inherit;text-decoration:none}
.ud-item a .ud-ico{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;opacity:.9; color: var(--brand)}
.ud-item a .ud-ico svg{width:18px;height:18px;fill:currentColor}
.ud-item a:hover{background:rgba(91,67,234,.06)}
.ud-item .badge{margin-right:auto;background:rgba(91,67,234,.1);color:var(--brand);font-size:11px;border-radius:999px;padding:2px 8px}
.ud-item.logout a{color:var(--danger)}
.ud-item.logout a .ud-ico{color: var(--danger)}
.ud-item a:focus-visible{outline:3px solid rgba(91,67,234,.25)}
.user-caret{transition:transform .16s ease}
.user-menu .open ~ .user-brief .user-caret{transform:rotate(180deg)}

@media (max-width:700px){
  .user-dropdown{
    position: relative;
    top: 56px; /* will be corrected by JS to header bottom */
    right: -120px;
    left: 8px;
    max-width: none;
  }
}

@media (max-width: 700px){
  .btn-head .label{display:none}
  .btn-head{padding:8px 10px;border-radius:10px}
  
  /* Small mobile purchase-bar */
  .purchase-bar{border-radius:12px}
  .purchase-bar .pb-label{font-size:13px}
  
  /* Small mobile service-card adjustments */
  .service-card{
    padding: 20px 16px;
    border-radius: 20px;
  }
  
  .service-header{
    padding: 12px 14px;
    margin-bottom: 18px;
  }
  
  .service-header .header-top{
    gap: 8px;
  }
  
  .service-header .name{
    font-size: 14px;
  }
  
  .service-header .rating{padding:0;font-size:11px;gap:4px}
  
  .service-header .star{
    font-size: 11px;
  }
  
  .service-header .header-bottom{
    gap: 8px;
  }
  
  .service-header .status-badge{
    padding: 3px 6px;
    font-size: 10px;
  }
}
.header-nav a:hover{text-decoration:underline}

.mega{position:relative}
.mega-panel{position:absolute;right:0;left:0;top:100%;background:#fff;border:1px solid var(--accent);border-radius:var(--radius);margin-top:8px;box-shadow:var(--shadow-md);overflow:hidden;z-index:100}
.mega-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:20px}
.mega-title{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-weight:700;font-size:14px;color:var(--ink);border-bottom:1px solid var(--accent);padding-bottom:8px}
.mega-icon{width:18px;height:18px;fill:var(--brand);flex-shrink:0}
.mega-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.mega-link{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;text-decoration:none;color:var(--ink-2);transition:all .2s ease;font-size:14px}
.mega-link:hover{background:var(--active-bg);color:var(--brand);text-decoration:none;transform:translateX(-2px)}
.mm-ico{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:6px;background:rgba(91,67,234,.08);fill:var(--brand);flex-shrink:0;transition:all .2s ease}
.mega-link:hover .mm-ico{background:var(--brand);fill:#fff;transform:scale(1.1)}

@media (max-width: 900px){
  .mega-panel{position:static;border-radius:var(--radius-sm);margin-top:12px}
  .mega-grid{grid-template-columns:1fr;gap:16px;padding:16px}
  .mega-title{font-size:13px;margin-bottom:10px}
  .mega-link{padding:6px 10px;font-size:13px}
  .mm-ico{width:18px;height:18px}
}

/* Mobile service header improvements */
@media (max-width: 900px){
  .service-header .header-top{
    gap: 8px;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
  
  .service-header .header-left{
    width: auto;
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
  }
  
  .service-header .name{
    font-size: 14px;
    width: 70%;
    flex: 1;
  }
  
  .service-header .rating{
    padding: 0;
    font-size: 11px;
    gap: 4px;
    width: auto;
    flex-shrink: 0;
    min-width: unset;
    animation: none;
  }
  
  .service-header .header-bottom{
    gap: 8px;
    width: 100%;
  }
  
  .service-header .status-badge{
    padding: 3px 6px;
    font-size: 10px;
  }
}

/* FAQ (minimal) */
.faq{background:#fff;padding:24px 0;margin-top:0;border-top:1px solid var(--accent);border-bottom:1px solid var(--accent)}
.faq-container{max-width:1200px;margin:0 auto;padding:20px 24px}
.faq-title{margin:0 0 24px;font-weight:800;font-size:20px;text-align:center;color:var(--ink)}
.faq-title::after{content:none}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.faq-col{min-width:0}
.product-intro{min-width:0}
.intro-card{background:#fff;border-radius:18px;padding:18px;box-shadow:0 4px 20px rgba(23,23,38,.04)}
.intro-title{margin:0 0 12px;font-weight:800;font-size:18px;color:var(--ink)}
.intro-desc{color:var(--ink-2);margin:12px 0 0}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--accent);border-radius:12px;padding:0;background:#fff;transition:background-color .2s ease,border-color .2s ease;position:relative;overflow:hidden}
.faq-item::before{content:none}
.faq-summary{cursor:pointer;padding:14px 16px;font-weight:600;display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:12px}
.faq-summary:hover{background:rgba(91,67,234,.04)}
.faq-summary::after{content:"\25BE";color:var(--ink-3);transition:transform .2s ease; font-size:14px}
.faq-item:hover{border-color:rgba(91,67,234,.2)}
.faq-item[open]{border-color:rgba(91,67,234,.2)}
.faq-item[open] .faq-summary{background:rgba(91,67,234,.04)}
.faq-item[open] .faq-summary::after{transform:rotate(180deg);opacity:.8}
.faq-content{padding:16px 18px;color:var(--ink-2);line-height:1.6;background:#fff}

@media (max-width: 900px){
  .faq-grid{grid-template-columns:1fr;gap:12px}
}

/* Tabs/Accordion */
.tabs{background:#fff;border:none !important}
.tabs-container{max-width:1200px;margin:0 auto;padding:25px}
.tab-list{position:relative;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.tab-list .tab-indicator{position:absolute;inset:auto 0 0 auto;height:36px;border-radius:999px;background:rgba(91,67,234,.08);box-shadow:0 2px 10px rgba(91,67,234,.12);transition:transform .25s ease,width .25s ease,opacity .2s ease;opacity:0;pointer-events:none;z-index:0}
.tab-btn{position:relative;z-index:1;border:1px solid var(--accent);background:#fff;border-radius:999px;padding:8px 12px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:color .2s ease,background-color .2s ease,border-color .2s ease,box-shadow .2s ease}
.tab-btn .ico{width:16px;height:16px;fill:currentColor}
.tab-btn:not(.active) .ico{fill:var(--purple) !important}
.tab-badge{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--ink-3);border:1px solid var(--accent);border-radius:999px;padding:2px 8px;font-size:12px;line-height:1}
.tab-badge .mini{width:10px;height:10px;fill:var(--brand);color:var(--brand);animation:tabDotBlink 1.2s ease-in-out infinite}
@keyframes tabDotBlink{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.1)}}
@media (prefers-reduced-motion: reduce){.tab-badge .mini{animation:none}}
.tab-btn:hover{background:rgba(91,67,234,.04);border-color:rgba(91,67,234,.25)}
.tab-btn.active{
  color: #fff;
  border-color: var(--brand);
  background: var(--brand);
  box-shadow: 0 2px 8px rgba(91,67,234,.2);
}

/* Hide sliding indicator on small screens to avoid oval shadow under first tab */
@media (max-width: 700px){
  .tab-list .tab-indicator{display:none !important}
}
/* Make reviews tab badge match active contrast (white on purple) */
.tab-btn.active .tab-badge{background:#ffffff20;color:#fff}
.tab-panels{background:#fff;border-radius:22px;padding:14px;border:1px solid #f5f5f5 !important}
.tab-panel{display:none;border:none !important}
.tab-panel.active{display:block;border:none !important}

/* Keep three tabs in one row on mobile with horizontal scroll */
@media (max-width: 700px){
  .tab-list{
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; /* Firefox */
    gap: 8px; /* preserve spacing while scrolling */
  }
  .tab-list::-webkit-scrollbar{ display: none; }
  .tab-btn{ flex: 0 0 auto; }
}

/* Reviews (light, modern, no heavy borders) */
.reviews{display:flex;flex-direction:column;gap:12px}
.review{background:#fff;border-radius:14px;padding:14px;box-shadow:0 1px 8px rgba(23,23,38,.06)}
.review-head{display:flex;align-items:center;gap:10px}
.avatar{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--panel);font-weight:700;color:var(--brand)}
.r-meta{display:flex;align-items:center;gap:8px;color:var(--ink-2);font-size:12px}
.r-name{font-weight:700;color:var(--ink)}
.r-stars{display:inline-flex;gap:2px;color:var(--gold)}
.r-stars svg{width:14px;height:14px}
.r-body{margin-top:8px;color:var(--ink);display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.r-admin{margin-top:10px;padding:10px 12px;border-radius:12px;background:rgba(91,67,234,.05)}
.r-admin .label{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--brand)}
.r-admin .text{margin-top:6px;color:var(--ink)}

/* Reviews container scroll & show-more spacing */
.tab-panel[data-tab="reviews"] .reviews{max-height:360px;overflow:auto;padding:8px 6px 0 0}
.tab-panel[data-tab="reviews"] .show-more{margin:12px 0 0}
.tab-panel[data-tab="reviews"] .load-more{border:1px solid var(--accent);background:#fff;border-radius:10px;padding:8px 12px;font-weight:700;color:var(--brand);cursor:pointer}
.tab-panel[data-tab="reviews"] .load-more:hover{background:rgba(91,67,234,.04);border-color:rgba(91,67,234,.25)}

/* Review form */
.review-form{margin-top:16px;border:1px solid var(--accent);background:#fff;border-radius:12px;padding:12px}
.rf-title{margin:16px 0 10px;font-weight:800;font-size:14px;color:var(--ink)}
.rf-grid{display:grid;grid-template-columns:1fr 120px;gap:8px;margin-bottom:8px}
.rf-field{display:flex;flex-direction:column;gap:6px}
.rf-label{font-size:12px;color:var(--ink-2);font-weight:700}
.review-form input,.review-form select,.review-form textarea{border:1px solid var(--accent);background:#fff;border-radius:10px;padding:8px 10px;font:inherit;min-height:40px}
.review-form textarea{min-height:96px;line-height:1.7}
.review-form input:focus,.review-form select:focus,.review-form textarea:focus{outline:2px solid rgba(91,67,234,.15);border-color:rgba(91,67,234,.35)}
.review-form .rf-counter{margin-top:4px;color:var(--ink-2);font-size:12px;text-align:left}
.review-form .rf-invalid{border-color:var(--danger) !important;background:rgba(224,49,49,.03)}
.rf-actions{display:flex;align-items:center;gap:10px;margin-top:8px}
.rf-actions .g-recaptcha{transform:scale(.9);transform-origin:right center}
.review-form .btn{padding:8px 12px;border-radius:10px}
.review-form .btn[disabled]{opacity:.6;cursor:not-allowed}
.form-error{color:var(--danger)}
.form-error.success{color:var(--success)}
@media (max-width: 600px){
  .rf-grid{grid-template-columns:1fr;}
}

/* Accessibility improvements */
.skip-link {
  position: absolute;
  top: -40px;
  left: 6px;
  background: var(--brand);
  color: white;
  padding: 8px;
  text-decoration: none;
  border-radius: 4px;
  z-index: 1000;
  transition: top 0.3s;
}

.skip-link:focus {
  top: 6px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Focus management for tabs */
.tab-btn:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

.tab-panel:focus {
  outline: none;
}

.tab-panel.active:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

/* Prevent mouse-click outlines on the panels wrapper */
.tab-panels:focus { outline: none; }
.video-box{border:1px dashed var(--accent);border-radius:12px;padding:20px;text-align:center;color:var(--ink-2)}

/* Related services (minimal) */
.related{background:#fff;padding:24px 0 12px;border-top:1px solid var(--accent);border-bottom:1px solid var(--accent)}
.related-container{max-width:1200px;margin:0 auto;padding:20px 24px}
.related-title{margin:0 0 24px;font-weight:800;font-size:20px;text-align:center;color:var(--ink)}
.related-title::after{content:none}
.related-grid{--related-gap:16px;display:flex;gap:var(--related-gap);overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:8px;scroll-snap-type:x mandatory;scroll-padding-inline:24px;cursor:grab;overscroll-behavior-x:contain}
.related-grid.auto-scroll{animation:slide-right 20s linear infinite}
.related-grid.auto-scroll:hover{animation-play-state: paused}
.related-grid.drag-ready,.related-grid.dragging{cursor:grabbing;user-select:none;-webkit-user-select:none}
.related-grid.dragging{scroll-snap-type:none}
.related-card{border-radius:12px;padding:16px;background:#fff;transition:background-color .2s ease, border-color .2s ease;position:relative;overflow:hidden;border:1px solid var(--accent);flex:0 0 var(--related-col, calc((100% - 3 * var(--related-gap)) / 4));scroll-snap-align:start}
.related-card{padding-top:32px}
.related-card::before{content:none}
.related-card:hover{background:rgba(91,67,234,.04);border-color:rgba(91,67,234,.2)}
.rc-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.rc-ico{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;background:rgba(91,67,234,.06);font-size:14px;color:var(--brand);font-weight:600;transition:background-color .2s ease}
.rc-ico:hover{background:rgba(91,67,234,.1)}
.rc-title{margin:0;font-weight:600;font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rc-title a{text-decoration:none;color:inherit;transition:color .3s ease}
.rc-title a:hover{color:var(--brand)}
.rc-rating{position:absolute;top:8px;left:8px;display:inline-flex;align-items:center;gap:6px;color:var(--gold);font-size:12px;background:rgba(255,255,255,.9);backdrop-filter:saturate(140%) blur(4px);border:1px solid var(--accent);border-radius:999px;padding:2px 8px}
.rc-rating .stars{display:inline-flex}
.rc-rating .stars svg{width:14px;height:14px;display:inline-block}
.rc-rating .stars svg path{fill:currentColor}
.rc-meta{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.rc-price{color:var(--brand);font-size:13px;font-weight:700;background:rgba(91,67,234,.06);padding:6px 10px;border-radius:8px}
.rc-btn{border:1px solid var(--accent);background:#fff;color:var(--ink);border-radius:12px;padding:10px 14px;cursor:pointer;font-weight:700;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;font-size:13px;display:inline-block;text-decoration:none}
.rc-btn:hover{background:rgba(91,67,234,.04);border-color:rgba(91,67,234,.2);text-decoration:none}
.rc-btn:active{transform:translateY(1px)}

/* Badge styles for related cards */
.badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.badge{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid}
.badge.success{background:rgba(34,197,94,.1);color:#22c55e;border-color:rgba(34,197,94,.2)}
.badge.discount{background:rgba(239,68,68,.1);color:#ef4444;border-color:rgba(239,68,68,.2)}
.badge.trend{background:rgba(59,130,246,.1);color:#3b82f6;border-color:rgba(59,130,246,.2)}
.badge.info{background:rgba(91,67,234,.1);color:var(--brand);border-color:rgba(91,67,234,.2)}
.badge.tag{background:rgba(168,85,247,.1);color:#a855f7;border-color:rgba(168,85,247,.2)}

/* Related responsive columns for carousel */
@media (min-width: 901px){
  .related-grid{--related-col: calc((100% - 3 * var(--related-gap)) / 4)}
}
@media (max-width: 900px){
  .related-grid{--related-col: calc((100% - var(--related-gap)) / 2)}
}
@media (max-width: 600px){
  .related-grid{--related-col: 78%}
}

/* Skeleton loading states */
.skeleton{background:linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}
@keyframes skeleton-loading{0%{background-position:200% 0}100%{background-position:-200% 0}}

@keyframes slide-right {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.skeleton-card{background:#fff;border:1px solid var(--accent);border-radius:var(--radius-sm);padding:16px;height:120px}
.skeleton-card__header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.skeleton-card__icon{width:40px;height:40px;border-radius:10px;background:var(--accent)}
.skeleton-card__title{height:16px;border-radius:4px;background:var(--accent);flex:1}
.skeleton-card__price{width:80px;height:14px;border-radius:4px;background:var(--accent);margin-left:auto}
.skeleton-card__desc{height:12px;border-radius:4px;background:var(--accent);margin-bottom:8px}
.skeleton-card__desc:last-child{width:60%}

/* Empty state for category level */
.empty-state{text-align:center;padding:48px 24px;background:#fff;border:1px solid var(--accent);border-radius:var(--radius);margin:24px auto;max-width:800px}

/* Empty state inside service panel */
.empty-state--inline{text-align:center;padding:32px 20px;background:#fff;border:1px solid var(--accent);border-radius:var(--radius-sm);margin:0;max-width:none;height:100%;display:flex;flex-direction:column;justify-content:center}
.empty-state--inline .empty-state__icon{width:48px;height:48px;font-size:20px;margin-bottom:12px}
.empty-state--inline .empty-state__title{font-size:16px;margin-bottom:6px}
.empty-state--inline .empty-state__desc{font-size:14px;margin-bottom:20px}
.empty-state--inline .empty-state__suggestions{grid-template-columns:repeat(2,1fr);gap:8px;max-width:400px}
.empty-state--inline .empty-state__suggestion{padding:8px 10px;font-size:13px}
.empty-state--inline .empty-state__suggestion-icon{width:20px;height:20px;font-size:10px}
.empty-state__icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg, rgba(91,67,234,.1), rgba(91,67,234,.15));display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px;color:var(--brand)}
.empty-state__title{font-weight:700;font-size:18px;margin:0 0 8px;color:var(--ink)}
.empty-state__desc{color:var(--ink-2);margin:0 0 24px;line-height:1.5}
.empty-state__suggestions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;max-width:600px;margin:0 auto}
.empty-state__suggestion{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--accent);border-radius:var(--radius-sm);background:#fff;text-decoration:none;color:inherit;transition:all .3s ease;font-size:14px}
.empty-state__suggestion:hover{border-color:var(--brand);background:var(--active-bg)}
.empty-state__suggestion-icon{width:24px;height:24px;border-radius:6px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--ink-2)}

/* Enhanced suggestion cards for subcategories */
.empty-state__suggestion {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--accent);
  border-radius: var(--radius-sm);
  background: #fff;
  text-decoration: none;
  color: inherit;
  transition: all .3s ease;
  font-size: 14px;
  min-height: 80px;
}

.empty-state__suggestion:hover {
  border-color: var(--brand);
  background: var(--active-bg);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(91,67,234,.1);
}

.suggestion-content {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}

.suggestion-title {
  font-weight: 600;
  color: var(--ink);
  font-size: 14px;
}

.suggestion-count {
  font-size: 12px;
  color: var(--success);
  font-weight: 500;
}

.suggestion-price {
  font-size: 12px;
  color: var(--brand);
  font-weight: 600;
}

.empty-state--inline .empty-state__suggestions {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
  max-width: none;
}

/* Skeleton grid for services */
.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin:24px auto;max-width:1200px}

/* Responsive adjustments for empty state and skeleton */
@media (max-width: 768px) {
  .empty-state {
    margin: 16px;
    padding: 32px 16px;
  }
  
  .empty-state__suggestions {
    grid-template-columns: 1fr;
  }
  
  .empty-state--inline {
    padding: 24px 16px;
  }
  
  .empty-state--inline .empty-state__suggestions {
    grid-template-columns: 1fr;
    max-width: none;
  }
  
  .skeleton-grid {
    margin: 16px;
    grid-template-columns: 1fr;
  }
}

/* Show more button styles */
.show-more-line {
  margin-top: 8px;
}

.show-more-btn {
  width: 100%;
  background: var(--accent);
  border: 1px solid var(--accent);
  color: var(--ink-2);
  font-weight: 500;
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all .3s ease;
  text-align: center;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.show-more-btn:hover {
  background: var(--brand);
  border-color: var(--brand);
  color: white;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(91,67,234,.2);
}

.show-more-btn:active {
  transform: translateY(0);
}

/* icon on the left end */
/* remove custom icon spacing when no icon */