/* =========================================================================
   AIOR — Astro renk paritesi (sadece WHMCS'te uygula)
   Astro home global.css canonical token'larını override ediyor; WHMCS
   canonical'ı saf yüklüyor. Aşağıdaki blok Astro'nun TÜM dark/light
   tokens'ını WHMCS'e taşır — XF/Astro etkilenmez.
   ========================================================================= */
:root,
:root[data-theme="light"] {
  --bg:           #ffffff;
  --bg-soft:      #f7f8fa;
  --bg-sunken:    #e9ecf2;
  --fg:           #0a0e1a;
  --fg-soft:      #1a1f2e;
  --fg-muted:     #6b7280;
  --line:         #e8eaed;
  --line-strong:  #d1d5db;
  --accent:       #1da1f2;
  --accent-deep:  #0d7fc2;
  --accent-soft:  #d8eefd;
  --brand:        #1da1f2;
  --brand-deep:   #0d7fc2;
  --brand-soft:   #d8eefd;
}
:root[data-theme="dark"] {
  --bg:           #1c1c1c;
  --bg-soft:      #2a2a2a;
  --bg-sunken:    #161616;
  --fg:           #f7f8f9;
  --fg-soft:      #d4d4d4;
  --fg-muted:     #a3a3a3;
  --line:         #303030;
  --line-strong:  #404040;
  --accent:       #4ab6f5;
  --accent-deep:  #1da1f2;
  --accent-soft:  #07203a;
  --brand:        #4ab6f5;
  --brand-deep:   #1da1f2;
  --brand-soft:   #07203a;
}

/* Astro global.css'in topbar-nav-link override'ı — canonical ikinci tanımı eziyor */
.topbar-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.5rem 0.85rem;
  border-radius: 0.375rem;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--fg-soft);
  letter-spacing: -0.005em;
  transition: color 140ms ease, background 140ms ease;
}
.topbar-nav-link:hover,
.topbar-nav-link[aria-current="page"],
.topbar-mega-toggle[aria-expanded="true"] {
  color: var(--accent);
}

/* =========================================================================
   AIOR — WHMCS-only CSS Shim
   -------------------------------------------------------------------------
   Loaded ONLY by WHMCS templates (templates/AiorWHMCS/includes/head.tpl).
   Astro & XenForo do not include this file.

   Provides:
   - Tailwind-equivalent utility classes (canonical header.html uses them)
   - Bootstrap-class compatibility shim (WHMCS templates were built with
     Bootstrap markup; we provide AIOR-styled rules for those classes)
   - WHMCS-specific layout primitives (aior-main, aior-side, aior-subnav, etc.)
   - WHMCS template ekstra bileşenler (status-pill, kb cat, ticket thread, etc.)

   Tüm renkler canonical aior-theme.css'teki design tokens'tan gelir.
   No Bootstrap/Tailwind library — pure CSS using AIOR vars.
   ========================================================================= */

/* ============================================================
   1. TAILWIND UTILITY SHIM
   Canonical header.html "lg:flex", "hidden", "mx-auto" etc.
   kullanıyor; Astro Tailwind'i compile ediyor, WHMCS'te shim.
   ============================================================ */

/* Display */
.block { display: block; }
.inline-block { display: inline-block; }
.inline { display: inline; }
.flex { display: flex; }
.inline-flex { display: inline-flex; }
.grid { display: grid; }
.hidden { display: none; }

/* Position */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }
.sticky { position: sticky; }
.static { position: static; }
.top-0 { top: 0; } .top-3 { top: 0.75rem; }
.left-0 { left: 0; } .left-3 { left: 0.75rem; }
.right-0 { right: 0; } .bottom-0 { bottom: 0; }
.inset-0 { top: 0; right: 0; bottom: 0; left: 0; }
.z-10 { z-index: 10; } .z-20 { z-index: 20; } .z-30 { z-index: 30; }
.z-40 { z-index: 40; } .z-50 { z-index: 50; }

/* Flex / grid */
.flex-1 { flex: 1 1 0%; }
.flex-auto { flex: 1 1 auto; }
.flex-shrink-0 { flex-shrink: 0; }
.flex-wrap { flex-wrap: wrap; }
.flex-nowrap { flex-wrap: nowrap; }
.flex-col { flex-direction: column; }
.flex-row { flex-direction: row; }
.items-start { align-items: flex-start; }
.items-center { align-items: center; }
.items-end { align-items: flex-end; }
.items-stretch { align-items: stretch; }
.justify-start { justify-content: flex-start; }
.justify-center { justify-content: center; }
.justify-end { justify-content: flex-end; }
.justify-between { justify-content: space-between; }
.justify-around { justify-content: space-around; }
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

/* Gap */
.gap-0 { gap: 0; }
.gap-1 { gap: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: 1rem; }
.gap-5 { gap: 1.25rem; }
.gap-6 { gap: 1.5rem; }
.gap-8 { gap: 2rem; }

/* Margin */
.m-0 { margin: 0; }
.mx-auto { margin-left: auto; margin-right: auto; }
.my-auto { margin-top: auto; margin-bottom: auto; }
.ml-auto { margin-left: auto; }
.mr-auto { margin-right: auto; }
.mt-1 { margin-top: 0.25rem; }
.mt-2 { margin-top: 0.5rem; }
.mt-3 { margin-top: 0.75rem; }
.mt-4 { margin-top: 1rem; }
.mt-6 { margin-top: 1.5rem; }
.mb-2 { margin-bottom: 0.5rem; }
.mb-4 { margin-bottom: 1rem; }
.mr-1 { margin-right: 0.25rem; }
.mr-2 { margin-right: 0.5rem; }
.ml-1 { margin-left: 0.25rem; }
.ml-2 { margin-left: 0.5rem; }
.ml-3 { margin-left: 0.75rem; }

/* Padding */
.p-0 { padding: 0; }
.p-1 { padding: 0.25rem; }
.p-2 { padding: 0.5rem; }
.p-3 { padding: 0.75rem; }
.p-4 { padding: 1rem; }
.p-6 { padding: 1.5rem; }
.px-2 { padding-left: 0.5rem; padding-right: 0.5rem; }
.px-3 { padding-left: 0.75rem; padding-right: 0.75rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.px-5 { padding-left: 1.25rem; padding-right: 1.25rem; }
.py-1 { padding-top: 0.25rem; padding-bottom: 0.25rem; }
.py-2 { padding-top: 0.5rem; padding-bottom: 0.5rem; }
.py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
.py-4 { padding-top: 1rem; padding-bottom: 1rem; }
.pt-3 { padding-top: 0.75rem; }
.pb-3 { padding-bottom: 0.75rem; }

/* Sizing */
.w-full { width: 100%; }
.w-auto { width: auto; }
.w-4 { width: 1rem; } .w-5 { width: 1.25rem; } .w-6 { width: 1.5rem; }
.w-8 { width: 2rem; } .w-10 { width: 2.5rem; } .w-12 { width: 3rem; }
.h-full { height: 100%; }
.h-auto { height: auto; }
.h-4 { height: 1rem; } .h-5 { height: 1.25rem; } .h-6 { height: 1.5rem; }
.h-8 { height: 2rem; } .h-10 { height: 2.5rem; } .h-12 { height: 3rem; } .h-16 { height: 4rem; }
.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }
.max-w-4xl { max-width: 56rem; }
.max-w-5xl { max-width: 64rem; }
.max-w-6xl { max-width: 72rem; }
.max-w-7xl { max-width: 80rem; }
.min-w-0 { min-width: 0; }

/* Border / radius */
.rounded { border-radius: 0.25rem; }
.rounded-sm { border-radius: 0.125rem; }
.rounded-md { border-radius: 0.375rem; }
.rounded-lg { border-radius: 0.5rem; }
.rounded-xl { border-radius: 0.75rem; }
.rounded-full { border-radius: 9999px; }

/* Typography */
.text-xs { font-size: 0.75rem; line-height: 1rem; }
.text-sm { font-size: 0.875rem; line-height: 1.25rem; }
.text-base { font-size: 1rem; line-height: 1.5rem; }
.text-lg { font-size: 1.125rem; line-height: 1.75rem; }
.text-xl { font-size: 1.25rem; line-height: 1.75rem; }
.text-2xl { font-size: 1.5rem; line-height: 2rem; }
.text-3xl { font-size: 1.875rem; line-height: 2.25rem; }
.font-normal { font-weight: 400; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }
.uppercase { text-transform: uppercase; }
.lowercase { text-transform: lowercase; }
.tracking-tight { letter-spacing: -0.025em; }
.tracking-wide { letter-spacing: 0.025em; }
.leading-tight { line-height: 1.25; }
.leading-snug { line-height: 1.375; }
.leading-normal { line-height: 1.5; }
.whitespace-nowrap { white-space: nowrap; }
.text-\[11px\] { font-size: 11px; line-height: 1; }
.text-\[11\.5px\] { font-size: 11.5px; line-height: 1.2; }
.text-\[12px\] { font-size: 12px; line-height: 1.2; }
.text-\[13px\] { font-size: 13px; line-height: 1.3; }

/* Text colors */
.text-white { color: #fff; }
.text-fg { color: var(--fg); }
.text-muted { color: var(--fg-muted); }
.bg-canvas { background-color: var(--bg); }
.bg-bg-soft { background-color: var(--bg-soft); }
.bg-\[var\(--brand-deep\)\] { background-color: var(--brand-deep); }
.antialiased { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

/* Cursor */
.cursor-pointer { cursor: pointer; }
.cursor-default { cursor: default; }
.cursor-not-allowed { cursor: not-allowed; }
.opacity-0 { opacity: 0; }
.opacity-50 { opacity: 0.5; }
.opacity-100 { opacity: 1; }
.pointer-events-none { pointer-events: none; }

/* Responsive breakpoints */
@media (min-width: 640px) {
  .sm\:flex { display: flex; }
  .sm\:inline-flex { display: inline-flex; }
  .sm\:inline { display: inline; }
  .sm\:block { display: block; }
  .sm\:hidden { display: none; }
  .sm\:gap-2 { gap: 0.5rem; }
  .sm\:gap-4 { gap: 1rem; }
  .sm\:gap-6 { gap: 1.5rem; }
  .sm\:px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
  .sm\:flex-row { flex-direction: row; }
  .sm\:text-left { text-align: left; }
}
@media (min-width: 768px) {
  .md\:flex { display: flex; }
  .md\:inline-flex { display: inline-flex; }
  .md\:hidden { display: none; }
  .md\:block { display: block; }
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .md\:px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
}
@media (min-width: 1024px) {
  .lg\:flex { display: flex; }
  .lg\:inline-flex { display: inline-flex; }
  .lg\:inline { display: inline; }
  .lg\:block { display: block; }
  .lg\:hidden { display: none; }
  .lg\:grid { display: grid; }
  .lg\:px-8 { padding-left: 2rem; padding-right: 2rem; }
  .lg\:ml-0 { margin-left: 0; }
  .lg\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.focus\:not-sr-only:focus {
  position: static;
  width: auto;
  height: auto;
  padding: revert;
  margin: revert;
  overflow: visible;
  clip: auto;
  white-space: normal;
}

/* ============================================================
   2. WHMCS LAYOUT PRIMITIVES
   ============================================================ */

.aior-main {
  background: var(--bg);
  padding: 28px 0 56px;
}
.aior-main-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 16px;
}
@media (min-width: 640px) { .aior-main-inner { padding: 0 24px; } }
@media (min-width: 1024px) { .aior-main-inner { padding: 0 32px; } }
.aior-main-inner-fluid { max-width: 100%; }
.aior-main-grid {
  display: grid;
  gap: 28px;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .aior-main-grid { grid-template-columns: 240px 1fr; }
  .aior-main-grid:has(.aior-side-secondary) { grid-template-columns: 240px 1fr 240px; }
}
.aior-main-content { min-width: 0; }

.aior-side {
  position: sticky;
  top: calc(var(--topbar-utility-h, 38px) + 64px + 24px);
  align-self: flex-start;
}
.aior-side-list {
  list-style: none;
  margin: 0;
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.aior-side-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--r-sm);
  color: var(--fg-soft);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  transition: background 160ms, color 160ms;
}
.aior-side-link:hover { background: var(--bg-soft); color: var(--fg); }
.aior-side-link.is-active {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-deep);
  font-weight: 600;
}
.aior-side-link i { color: var(--fg-muted); width: 16px; text-align: center; }
.aior-side-link.is-active i { color: var(--accent-deep); }
.aior-side-link-count {
  margin-left: auto;
  padding: 1px 7px;
  border-radius: 999px;
  background: var(--bg-soft);
  font-size: 11px;
  color: var(--fg-muted);
}

.aior-subnav {
  position: sticky;
  top: calc(var(--topbar-utility-h, 38px) + 64px);
  z-index: 40;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  margin-bottom: 24px;
}
.aior-subnav-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 12px 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  overflow-x: auto;
}
@media (min-width: 1024px) { .aior-subnav-inner { padding: 12px 32px; } }
.aior-subnav-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: var(--r-sm);
  color: var(--fg-soft);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  white-space: nowrap;
  transition: background 160ms, color 160ms;
}
.aior-subnav-link:hover { background: var(--bg-soft); color: var(--fg); }
.aior-subnav-link.is-active {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-deep);
  font-weight: 600;
}

/* Page header */
.aior-page-header {
  margin-bottom: 24px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.aior-page-header h1 {
  margin: 0 0 6px;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--fg);
}
.aior-page-header p { margin: 0; font-size: 14px; color: var(--fg-muted); line-height: 1.55; }

/* Stats grid */
.aior-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (min-width: 768px) { .aior-stats-grid { grid-template-columns: repeat(4, 1fr); } }
.aior-stat-card {
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  padding: 22px 14px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--fg);
  text-decoration: none;
  transition: transform 160ms, box-shadow 160ms, border-color 160ms;
}
.aior-stat-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--accent) 30%, var(--line));
  box-shadow: 0 8px 24px -10px color-mix(in srgb, var(--accent) 25%, transparent);
}
.aior-stat-icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-deep);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 20px;
  margin-bottom: 12px;
}
.aior-stat-value { margin: 0; font-size: 28px; font-weight: 700; letter-spacing: -0.02em; color: var(--fg); line-height: 1; }
.aior-stat-label { margin: 6px 0 0; font-size: 12.5px; letter-spacing: 0.04em; color: var(--fg-muted); font-weight: 500; }

/* Definition list */
.aior-deflist { margin: 0; display: grid; gap: 14px; }
.aior-deflist > div {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
  padding-bottom: 12px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
}
@media (min-width: 640px) {
  .aior-deflist > div { grid-template-columns: 200px 1fr; gap: 14px; align-items: baseline; }
}
.aior-deflist > div:last-child { border-bottom: 0; padding-bottom: 0; }
.aior-deflist dt { margin: 0; font-size: 12.5px; font-weight: 600; color: var(--fg-muted); letter-spacing: 0.02em; }
.aior-deflist dd { margin: 0; font-size: 14px; color: var(--fg); }

/* Status pill */
.aior-status-pill {
  display: inline-flex; align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11.5px; font-weight: 600; letter-spacing: 0.04em;
  border: 1px solid currentColor;
  white-space: nowrap;
}
.aior-status-paid, .aior-status-active     { color: #16a34a; background: color-mix(in srgb, #16a34a 10%, transparent); }
.aior-status-unpaid, .aior-status-pending  { color: #ea580c; background: color-mix(in srgb, #ea580c 10%, transparent); }
.aior-status-overdue, .aior-status-suspended,
.aior-status-cancelled, .aior-status-terminated { color: #dc2626; background: color-mix(in srgb, #dc2626 10%, transparent); }
.aior-status-open, .aior-status-answered   { color: var(--accent-deep); background: color-mix(in srgb, var(--accent) 12%, transparent); }
.aior-status-closed, .aior-status-completed { color: var(--fg-muted); background: var(--bg-soft); }
.aior-status-customer-reply { color: #f59e0b; background: color-mix(in srgb, #f59e0b 12%, transparent); }
.aior-status-on-hold        { color: #6b7280; background: color-mix(in srgb, #6b7280 12%, transparent); }

/* Pill */
.aior-pill {
  display: inline-flex; align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
  background: var(--bg-soft); color: var(--fg-soft);
}
.aior-pill-accent { background: color-mix(in srgb, var(--accent) 10%, transparent); color: var(--accent-deep); }

/* Text utilities */
.aior-text-muted { color: var(--fg-muted); }
.aior-text-soft { color: var(--fg-soft); }
.aior-text-danger { color: #dc2626; }
.aior-text-strong { color: var(--fg); font-weight: 600; }

/* Link */
.aior-link { color: var(--accent-deep); text-decoration: none; font-weight: 500; transition: color 160ms; }
.aior-link:hover { color: var(--accent); text-decoration: underline; }

/* Form primitives */
.aior-form { display: flex; flex-direction: column; gap: 24px; }
.aior-form-narrow { max-width: 32rem; }
.aior-form-group { display: block; }
.aior-form-group + .aior-form-group { margin-top: 14px; }
.aior-form-help { margin-top: 6px; font-size: 12px; color: var(--fg-muted); }
.aior-form-actions {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  padding-top: 8px;
}
.aior-section-title {
  margin: 0 0 12px;
  font-size: var(--fs-md, 1rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fg);
}

/* Inline checkbox */
.aior-checkbox-row {
  display: flex; align-items: flex-start;
  gap: 10px;
  font-size: 14px; line-height: 1.5;
  color: var(--fg-soft);
  cursor: pointer;
}
.aior-checkbox-row input[type="checkbox"],
.aior-checkbox-row input[type="radio"] {
  width: 16px; height: 16px;
  margin-top: 2px;
  accent-color: var(--accent);
  flex-shrink: 0;
}
.aior-checkbox-row span { flex: 1; }

.aior-perms-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 10px 24px;
  margin-top: 14px;
}
@media (min-width: 640px) { .aior-perms-grid { grid-template-columns: repeat(2, 1fr); } }

/* Records-per-page */
.aior-records-limit { display: inline-flex; align-items: center; gap: 8px; margin-left: auto; margin-top: 16px; }
.aior-records-label { font-size: 12.5px; color: var(--fg-muted); margin: 0; }
.aior-records-select {
  height: 32px; padding: 0 8px;
  font-size: 13px;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: var(--bg);
  color: var(--fg);
}

/* Auth shell */
.aior-auth-shell {
  display: flex; align-items: center; justify-content: center;
  min-height: 60vh;
  padding: 32px 16px;
}
.aior-auth-card {
  width: 100%; max-width: 26rem;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  text-align: center;
  box-shadow: 0 16px 40px -20px rgba(15, 23, 42, 0.18);
}
:root[data-theme="dark"] .aior-auth-card { background: var(--bg-soft); box-shadow: 0 16px 40px -20px rgba(0, 0, 0, 0.55); }
.aior-auth-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-deep);
  margin: 0 auto 20px;
}
.aior-auth-title { margin: 0 0 16px; font-size: 22px; font-weight: 700; letter-spacing: -0.015em; color: var(--fg); }
.aior-auth-subtitle { margin: 16px 0 8px; font-size: 16px; font-weight: 600; color: var(--fg); }
.aior-2fa-challenge { margin: 16px 0; }
.aior-2fa-challenge .form-control,
.aior-2fa-challenge input[type="text"],
.aior-2fa-challenge input[type="number"] {
  width: 100%; height: 48px; padding: 0 14px;
  font: inherit; font-size: 18px; letter-spacing: 0.2em; text-align: center;
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  color: var(--fg); background: var(--bg);
  border: 1px solid var(--line); border-radius: var(--r-md);
}
.aior-2fa-challenge .form-control:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-ring); outline: none; }

.aior-info-panel {
  margin-top: 20px;
  padding: 14px 16px;
  background: color-mix(in srgb, var(--accent) 6%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--line));
  border-radius: var(--r-md);
  text-align: left;
}
.aior-info-title { margin: 0 0 6px; font-size: 13px; font-weight: 700; color: var(--fg); }

/* ============================================================
   AUTH PAGE (login.tpl, pwreset.tpl) — 2 col card + side panel
   ============================================================ */
.aior-auth-page {
  padding: 8px 0 24px;
}
.aior-auth-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  max-width: 60rem;
  margin: 0 auto;
  padding: 0 16px;
}
@media (min-width: 900px) {
  .aior-auth-container {
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 28px;
    align-items: start;
  }
}

/* Override existing .aior-auth-card (2FA-shell variant): inside auth-page, full-width left-aligned */
.aior-auth-page .aior-auth-card {
  width: auto;
  max-width: none;
  text-align: left;
  padding: 28px 28px 24px;
}
.aior-auth-header { text-align: center; margin-bottom: 24px; }
.aior-auth-page .aior-auth-title {
  margin: 0 0 6px;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--fg);
}
.aior-auth-subtitle {
  margin: 0;
  font-size: 14px;
  font-weight: 400;
  color: var(--fg-muted);
  line-height: 1.5;
}

/* Label row (label + small action link to the right) */
.aior-label-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.aior-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-soft);
  letter-spacing: -0.005em;
  margin: 0;
}
.aior-link-sm { font-size: 13px; }

/* Input wrap + show/hide action button */
.aior-input-wrap .aior-input { padding-left: 40px; padding-right: 44px; }
.aior-input-action {
  position: absolute;
  right: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border: 0;
  border-radius: var(--r-sm);
  color: var(--fg-muted);
  cursor: pointer;
  transition: color 160ms, background 160ms;
}
.aior-input-action:hover { color: var(--fg); background: var(--bg-soft); }

/* Checkbox (custom mark) */
.aior-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 14px;
  color: var(--fg-soft);
  user-select: none;
  position: relative;
  white-space: nowrap;
}
.aior-checkbox > span:not(.aior-checkbox-mark) { white-space: nowrap; }
.aior-checkbox input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}
.aior-checkbox-mark {
  width: 18px;
  height: 18px;
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  background: var(--bg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: border-color 160ms, background 160ms;
}
.aior-checkbox input[type="checkbox"]:checked + .aior-checkbox-mark {
  border-color: var(--accent);
  background: var(--accent);
}
.aior-checkbox input[type="checkbox"]:checked + .aior-checkbox-mark::after {
  content: "";
  width: 5px;
  height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg) translate(0, -1px);
}
.aior-checkbox input[type="checkbox"]:focus-visible + .aior-checkbox-mark {
  box-shadow: 0 0 0 3px var(--accent-ring, rgba(74,182,245,0.18));
}

/* Footer text inside card (sign-up prompt) */
.aior-auth-footer {
  margin: 8px 0 0;
  font-size: 14px;
  color: var(--fg-muted);
  text-align: center;
}

/* Divider — "or" separator before SSO buttons (subtle, thin) */
.aior-auth-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 22px 0 14px;
  color: var(--fg-muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 500;
}
.aior-auth-divider::before,
.aior-auth-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--line) 40%, var(--line) 60%, transparent);
}

/* SSO provider buttons — AIOR custom render (linkedaccounts.tpl).
   Equal width, brand SVG icons, single-word labels. WHMCS native button
   HTML is bypassed at the TPL level for login/registration contexts. */
.aior-auth-providers .aior-sso-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}
.aior-sso-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 44px;
  padding: 0 16px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg);
  color: var(--fg);
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: background 160ms, border-color 160ms, color 160ms, transform 160ms;
  white-space: nowrap;
  overflow: hidden;
  cursor: pointer;
}
.aior-sso-btn:hover {
  background: var(--bg-soft);
  border-color: var(--line-strong);
  color: var(--fg);
  text-decoration: none;
}
.aior-sso-btn:active { transform: translateY(1px); }
/* SSO brand icons via CSS background (data: URI SVG). Bypass canonical's
   svg { height: auto } restriction entirely — span+background renders
   100% reliably regardless of what other svg rules exist. */
.aior-sso-icon {
  flex: 0 0 18px;
  width: 18px;
  height: 18px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
}
.aior-sso-facebook .aior-sso-icon {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%231877F2' d='M24 12.073C24 5.405 18.627 0 12 0S0 5.405 0 12.073c0 6.019 4.388 11.011 10.125 11.927v-8.437H7.078v-3.49h3.047V9.413c0-3.014 1.792-4.679 4.532-4.679 1.313 0 2.686.235 2.686.235v2.965h-1.514c-1.491 0-1.956.93-1.956 1.886v2.263h3.328l-.532 3.49h-2.796V24C19.612 23.084 24 18.092 24 12.073z'/></svg>");
}
.aior-sso-google .aior-sso-icon {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'><path fill='%23FFC107' d='M43.611 20.083H42V20H24v8h11.303c-1.649 4.657-6.08 8-11.303 8-6.627 0-12-5.373-12-12s5.373-12 12-12c3.059 0 5.842 1.154 7.961 3.039l5.657-5.657C34.046 6.053 29.268 4 24 4 12.955 4 4 12.955 4 24s8.955 20 20 20 20-8.955 20-20c0-1.341-.138-2.65-.389-3.917z'/><path fill='%23FF3D00' d='m6.306 14.691 6.571 4.819C14.655 15.108 18.961 12 24 12c3.059 0 5.842 1.154 7.961 3.039l5.657-5.657C34.046 6.053 29.268 4 24 4 16.318 4 9.656 8.337 6.306 14.691z'/><path fill='%234CAF50' d='M24 44c5.166 0 9.86-1.977 13.409-5.192l-6.19-5.238A11.91 11.91 0 0 1 24 36c-5.202 0-9.619-3.317-11.283-7.946l-6.522 5.025C9.505 39.556 16.227 44 24 44z'/><path fill='%231976D2' d='M43.611 20.083H42V20H24v8h11.303a12.04 12.04 0 0 1-4.087 5.571l.003-.002 6.19 5.238C36.971 39.205 44 34 44 24c0-1.341-.138-2.65-.389-3.917z'/></svg>");
}
.aior-sso-twitter .aior-sso-icon,
.aior-sso-x       .aior-sso-icon {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z'/></svg>");
}
:root[data-theme="light"] .aior-sso-twitter .aior-sso-icon,
:root[data-theme="light"] .aior-sso-x       .aior-sso-icon {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23000000' d='M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z'/></svg>");
}
.aior-sso-label {
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: -0.005em;
}

/* Brand-tinted hover accents (subtle — keeps surface neutral) */
.aior-sso-facebook:hover { color: #1877f2; border-color: color-mix(in srgb, #1877f2 50%, var(--line)); }
.aior-sso-google:hover   { border-color: color-mix(in srgb, #4285f4 50%, var(--line)); }
.aior-sso-twitter:hover,
.aior-sso-x:hover        { color: var(--fg); border-color: color-mix(in srgb, #ffffff 30%, var(--line-strong)); }

/* Hide native WHMCS provider HTML if it ever leaks into login/registration */
.aior-auth-card .social-signin-btns:not(.aior-sso-row) > script,
.aior-auth-card .social-signin-btns:not(.aior-sso-row) > .fb-login-button,
.aior-auth-card .social-signin-btns:not(.aior-sso-row) > .g_id_signin,
.aior-auth-card .social-signin-btns:not(.aior-sso-row) > #g_id_onload { display: none !important; }

/* Captcha wrap (recaptcha/hcaptcha center) */
.aior-captcha { display: flex; justify-content: center; margin: 4px 0; }

/* Side panel (right column) — ferah, accent vurgulu */
.aior-auth-side {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 6%, var(--bg-soft)) 0%, var(--bg-soft) 60%);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 24px 22px;
  position: relative;
  overflow: hidden;
}
.aior-auth-side::before {
  /* hafif accent ışığı */
  content: "";
  position: absolute;
  top: -40px; right: -40px;
  width: 140px; height: 140px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 18%, transparent) 0%, transparent 70%);
  pointer-events: none;
}
.aior-auth-side-content {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.aior-auth-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--accent), var(--accent-deep));
  color: #fff;
  font-size: 18px;
  box-shadow: 0 6px 20px -8px var(--accent);
}
.aior-auth-badge i,
.aior-auth-badge > svg { color: #fff; line-height: 1; }

/* Logo variant — pure AIOR brand mark, no chrome, left-aligned. */
.aior-auth-badge-logo {
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  background: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  border: 0 !important;
  align-self: flex-start;
  justify-content: flex-start !important;
  margin-right: auto;
}
.aior-auth-badge-logo img {
  display: none;
  width: auto;
  height: 44px;
  max-width: none;
}
:root:not([data-theme="dark"]) .aior-auth-badge-logo .aior-brand-light { display: block; }
:root[data-theme="dark"]        .aior-auth-badge-logo .aior-brand-dark  { display: block; }
.aior-auth-side-title {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--fg);
  line-height: 1.35;
}
.aior-auth-side-list {
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.aior-auth-side-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13.5px;
  color: var(--fg-soft);
  line-height: 1.5;
}
.aior-auth-side-list li i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  font-size: 9px;
  margin-top: 2px;
  flex-shrink: 0;
}
.aior-auth-side-footer {
  margin: 6px 0 0;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-size: 13px;
  color: var(--fg-muted);
  line-height: 1.5;
}

/* Tighten form spacing inside auth card */
.aior-auth-page .aior-form { gap: 18px; }

/* ============================================================
   REGISTER PAGE (clientregister.tpl) — section headings outside
   large rounded cards, placeholder-driven inputs, brand-colored
   SSO row, toggle switch for mailing list. Reference design.
   ============================================================ */

.aior-register-shell {
  max-width: 60rem;
  margin: 0 auto;
  padding: 8px 16px 32px;
}

/* Top "Sign Up" pill — sits ABOVE a full-width divider line */
.aior-reg-tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  margin: 4px 0 28px;
}
.aior-reg-tab-pill {
  flex: 0 0 auto;
  padding: 9px 22px;
  background: var(--bg);
  color: var(--accent);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.aior-reg-tab-line {
  width: 100%;
  height: 1px;
  background: var(--line);
}

/* ============================================================
   4-STEP REGISTER WIZARD — progress bar + step pages + math captcha
   ============================================================ */
.aior-reg-progress {
  list-style: none;
  margin: 0 0 32px;
  padding: 0;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 1fr;
  gap: 0;
  position: relative;
}
.aior-reg-progress::before {
  content: "";
  position: absolute;
  top: 17px;
  /* Connector line spans from center of first circle to center of last —
     compute dynamically based on number of children (n) so 3 / 4 steps both
     align: side margin = 100% / (2n). */
  left: calc(50% / var(--aior-progress-n, 4));
  right: calc(50% / var(--aior-progress-n, 4));
  height: 2px;
  background: var(--line);
  z-index: 0;
}
.aior-reg-progress[data-steps="3"] { --aior-progress-n: 3; }
.aior-reg-progress[data-steps="4"] { --aior-progress-n: 4; }
.aior-reg-progress[data-steps="5"] { --aior-progress-n: 5; }

/* Math captcha row */
.aior-reg-math {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.aior-reg-math-q {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background: var(--bg-sunken, var(--bg));
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 22px;
  font-weight: 600;
  color: var(--fg);
  letter-spacing: 0.04em;
  user-select: none;
}
.aior-reg-math-q [data-aior-math-op] { color: var(--accent); margin: 0 4px; }
.aior-reg-math-q .aior-reg-math-eq { color: var(--fg-muted); margin-left: 4px; }
.aior-reg-math-input {
  width: 80px !important;
  text-align: center;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 18px;
  font-weight: 600;
}
.aior-reg-math-refresh {
  height: 44px;
  width: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--fg-muted);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: color 160ms, border-color 160ms;
}
.aior-reg-math-refresh:hover { color: var(--accent); border-color: var(--accent); }

/* Completed-action buttons — green background + check icon when a step
   verification succeeds. Appears on math/email/sms verify buttons. */
.aior-btn.is-done {
  background: #16a34a !important;        /* emerald-600 */
  color: #ffffff !important;
  border-color: #16a34a !important;
  cursor: default;
  opacity: 1 !important;
  box-shadow: 0 4px 14px -6px rgba(22, 163, 74, 0.55);
  transition: background 200ms, box-shadow 200ms;
}
.aior-btn.is-done:hover { background: #16a34a !important; }
.aior-btn.is-done .aior-done-check,
.aior-otp-send-btn.is-done .aior-done-check,
.aior-otp-verify-btn.is-done .aior-done-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  margin-right: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.22);
  color: #ffffff;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  animation: aiorDoneCheckPop 320ms cubic-bezier(.34,1.56,.64,1);
}
@keyframes aiorDoneCheckPop {
  0%   { transform: scale(0)   rotate(-30deg); opacity: 0; }
  60%  { transform: scale(1.2) rotate(8deg);   opacity: 1; }
  100% { transform: scale(1)   rotate(0);      opacity: 1; }
}
/* SSO-style send/verify buttons (smaller) — same treatment */
.aior-otp-send-btn.is-done,
.aior-otp-verify-btn.is-done {
  background: #16a34a !important;
  color: #ffffff !important;
}

/* Login info card — centered, AIOR brand + 2-col icon list of panel features */
.aior-login-info-card {
  margin-top: 22px;
  padding: 28px 24px 22px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 5%, var(--bg-soft)) 0%, var(--bg-soft) 60%);
  border: 1px solid var(--line);
  border-radius: 14px;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.aior-login-info-card::before {
  content: "";
  position: absolute;
  top: -50px; right: -50px;
  width: 180px; height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 16%, transparent) 0%, transparent 70%);
  pointer-events: none;
}
.aior-login-info-card::after {
  content: "";
  position: absolute;
  bottom: -50px; left: -50px;
  width: 180px; height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 10%, transparent) 0%, transparent 70%);
  pointer-events: none;
}
.aior-login-info-logo {
  display: flex;
  justify-content: center;
  margin: 0 0 12px;
  position: relative;
}
.aior-login-info-logo img {
  display: none;
  width: auto;
  height: 36px;
  max-width: none;
}
:root:not([data-theme="dark"]) .aior-login-info-logo .aior-brand-light { display: block; }
:root[data-theme="dark"]        .aior-login-info-logo .aior-brand-dark  { display: block; }
.aior-login-info-title {
  margin: 0 0 6px;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fg);
  position: relative;
}
.aior-login-info-sub {
  margin: 0 0 20px;
  font-size: 13.5px;
  color: var(--fg-muted);
  line-height: 1.5;
  position: relative;
}
.aior-login-info-list {
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 16px;
  position: relative;
  text-align: left;
}
@media (max-width: 480px) {
  .aior-login-info-list { grid-template-columns: 1fr; }
}
.aior-login-info-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--bg-soft) 60%, transparent);
  border: 1px solid var(--line);
  border-radius: 10px;
  font-size: 13.5px;
  color: var(--fg-soft);
  line-height: 1.4;
  transition: border-color 160ms, background 160ms;
}
.aior-login-info-list li:hover {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--line));
  background: color-mix(in srgb, var(--accent) 6%, var(--bg-soft));
}
.aior-login-info-list li i {
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
  font-size: 13px;
}
.aior-feat-check {
  flex: 0 0 22px;
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #16a34a;
  color: #ffffff;
  font-size: 13px;
  font-weight: 900;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  line-height: 1;
  box-shadow: 0 2px 6px -2px rgba(22, 163, 74, 0.55);
}
.aior-login-info-footer {
  margin: 0;
  padding-top: 16px;
  border-top: 1px solid var(--line);
  font-size: 13px;
  color: var(--fg-muted);
  position: relative;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
}

/* IP ban banner — sticky red strip at the top of the wizard, visible across steps */
.aior-reg-ban-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 0 0 22px;
  padding: 14px 22px;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, #7f1d1d, #991b1b);
  border: 1px solid rgba(239, 68, 68, 0.55);
  color: #ffffff;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.005em;
  text-align: center;
  box-shadow: 0 8px 24px -8px rgba(239, 68, 68, 0.45);
}
.aior-reg-ban-banner i { font-size: 18px; flex-shrink: 0; }
.aior-reg-progress-step {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--fg-muted);
}
.aior-reg-progress-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--bg-soft);
  border: 2px solid var(--line);
  color: var(--fg-muted);
  font-size: 14px;
  font-weight: 600;
  transition: background 200ms, border-color 200ms, color 200ms, box-shadow 200ms;
}
.aior-reg-progress-step.is-current .aior-reg-progress-num {
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
}
.aior-reg-progress-step.is-current { color: var(--fg); font-weight: 600; }
.aior-reg-progress-step.is-done .aior-reg-progress-num {
  background: #16a34a;          /* emerald-600 (matches done buttons) */
  border-color: #16a34a;
  color: #ffffff;
  font-size: 0;
  box-shadow: 0 4px 14px -6px rgba(22, 163, 74, 0.55);
}
.aior-reg-progress-step.is-done .aior-reg-progress-num::before {
  content: "✓";                /* Unicode U+2713 — universal, no font dependency */
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  font-weight: 900;
  font-size: 18px;
  line-height: 1;
  color: #ffffff;
}
.aior-reg-progress-step.is-done { color: #16a34a; font-weight: 600; }
.aior-reg-progress-step.is-done .aior-reg-progress-label { color: #16a34a; }

.aior-reg-step[hidden] { display: none; }
.aior-reg-step-desc {
  margin: 0 0 18px;
  font-size: 14px;
  color: var(--fg-soft);
  line-height: 1.6;
}
.aior-reg-step-actions {
  display: flex;
  gap: 12px;
  margin-top: 20px;
  flex-wrap: wrap;
}
.aior-reg-step-btn {
  height: 46px;
  padding: 0 28px;
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--r-md);
}
.aior-reg-step-msg {
  margin: 12px 0 0;
  min-height: 18px;
  font-size: 13px;
  letter-spacing: -0.005em;
}
.aior-reg-step-msg[data-kind="error"]   { color: #ef4444; }
.aior-reg-step-msg[data-kind="warn"]    { color: #f59e0b; }
.aior-reg-step-msg[data-kind="success"] { color: #10b981; }
.aior-reg-step-msg[data-kind="info"]    { color: var(--fg-soft); }

.aior-reg-step-sent {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  padding: 12px 0;
}
.aior-reg-step-sent-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
  font-size: 26px;
  margin-bottom: 4px;
}
.aior-reg-step-sent h3 { margin: 0; font-size: 18px; font-weight: 600; color: var(--fg); }
.aior-reg-step-sent-desc { margin: 0; max-width: 48ch; font-size: 14px; color: var(--fg-soft); line-height: 1.55; }
.aior-reg-step-sent-email {
  margin: 4px 0 8px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 14px;
  color: var(--accent);
}
.aior-reg-resend-btn { height: 38px; padding: 0 18px; font-size: 13px; }
.aior-reg-resend-cd { color: var(--fg-muted); }

.aior-reg-entity-toggle {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.aior-reg-entity-option { cursor: pointer; display: block; }
.aior-reg-entity-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.aior-reg-entity-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 18px 14px;
  background: var(--bg-sunken, var(--bg));
  border: 2px solid var(--line);
  border-radius: var(--r-md);
  text-align: center;
  transition: border-color 160ms, background 160ms, transform 160ms;
}
.aior-reg-entity-card i {
  font-size: 22px;
  color: var(--fg-muted);
  transition: color 160ms;
}
.aior-reg-entity-card strong { font-size: 14px; font-weight: 600; color: var(--fg); }
.aior-reg-entity-card small { font-size: 12px; color: var(--fg-muted); }
.aior-reg-entity-option input:checked + .aior-reg-entity-card {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--bg-sunken, var(--bg)));
  transform: translateY(-1px);
  box-shadow: 0 4px 12px -6px color-mix(in srgb, var(--accent) 40%, transparent);
}
.aior-reg-entity-option input:checked + .aior-reg-entity-card i { color: var(--accent); }
.aior-reg-entity-fields[hidden] { display: none; }

.aior-otp-row {
  display: flex;
  gap: 10px;
  margin-top: 14px;
  align-items: stretch;
}
.aior-otp-input {
  flex: 1 1 auto;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  letter-spacing: 0.18em;
  font-size: 16px;
}
.aior-otp-send-btn,
.aior-otp-verify-btn {
  flex: 0 0 auto;
  height: 44px;
  padding: 0 18px;
  background: var(--accent);
  color: #ffffff;
  border: 0;
  border-radius: var(--r-md);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: background 160ms;
}
.aior-otp-send-btn:hover,
.aior-otp-verify-btn:hover { background: var(--accent-deep); }
.aior-phone-field .aior-otp-send-btn {
  border-radius: 0 var(--r-md) var(--r-md) 0;
}

/* Important legal notice — animated blue↔green gradient banner. Sits between
   the "Kayıt Ol" pill and SSO row at top of register page. */
.aior-reg-notice {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  margin: 0 0 24px;
  padding: 14px 22px;
  border-radius: var(--r-md);
  background: linear-gradient(
    90deg,
    #1da1f2 0%,
    #06b6d4 25%,
    #10b981 50%,
    #06b6d4 75%,
    #1da1f2 100%
  );
  background-size: 300% 100%;
  background-position: 0% 50%;
  border: 1px solid rgba(16, 185, 129, 0.45);
  color: #ffffff;
  font-size: 14.5px;
  font-weight: 600;
  letter-spacing: -0.005em;
  text-align: center;
  box-shadow: 0 0 0 0 rgba(29, 161, 242, 0.4);
  animation:
    aiorRegNoticeShift 6s linear infinite,
    aiorRegNoticePulse 2.2s ease-in-out infinite;
  cursor: default;
  user-select: none;
}
.aior-reg-notice-icon {
  flex: 0 0 auto;
  font-size: 16px;
  color: #ffffff;
  filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.45));
}
.aior-reg-notice-text { flex: 0 1 auto; text-shadow: 0 1px 2px rgba(0,0,0,0.18); }

/* Background gradient slowly slides left↔right (blue → cyan → green ↔) */
@keyframes aiorRegNoticeShift {
  0%   { background-position:   0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position:   0% 50%; }
}

/* Soft pulse ring blends from accent blue to emerald green */
@keyframes aiorRegNoticePulse {
  0% {
    box-shadow: 0 0 0 0 rgba(29, 161, 242, 0.55),
                0 0 0 0 rgba(16, 185, 129, 0.35);
    transform: translateY(0);
  }
  50% {
    box-shadow: 0 0 0 12px rgba(16, 185, 129, 0),
                0 8px 28px -4px rgba(29, 161, 242, 0.45);
    transform: translateY(-1px);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(16, 185, 129, 0),
                0 0 0 0 rgba(29, 161, 242, 0);
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .aior-reg-notice { animation: none; background-position: 50% 50%; }
}

/* Uniform spacing system — all section gaps are 32px regardless of nesting.
   Rules apply to ELEMENTS, not parents, so wrapper divs (#containerNewUserSignup,
   #containerNewUserSecurity) don't add extra space. */
.aior-register-shell .aior-reg-heading {
  margin: 32px 0 0 !important;  /* gap from anything above */
}
.aior-register-shell .aior-reg-card {
  margin: 0 !important;  /* sit flush below heading */
}
.aior-register-shell .aior-reg-sso {
  margin: 0;  /* SSO row is the very first; gap to following heading via heading's own margin-top */
}
.aior-register-shell .aior-reg-actions {
  margin: 32px 0 0;
}
/* Heading immediately after the SSO row gets the same 32px gap (already applied
   via .aior-reg-heading rule). First heading inside .aior-reg-stack would normally
   be first-of-type but SSO is before it; rule still works.
   For wrapper divs: they have margin: 0 by default; their inner first-child h2's
   margin-top: 32px provides the section gap. */
.aior-register-shell #containerNewUserSignup,
.aior-register-shell #containerNewUserSecurity {
  margin: 0;
}

/* SSO providers row at top — brand-colored, horizontal */
.aior-reg-sso {
  margin-bottom: 4px;
}
.aior-reg-sso .aior-sso-row {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}
.aior-reg-sso .aior-sso-btn {
  flex: 1 1 0;
  min-width: 180px;
  height: 44px;
  font-weight: 500;
  border-width: 0;
}
.aior-reg-sso .aior-sso-facebook {
  background: #1877F2;
  color: #ffffff;
}
.aior-reg-sso .aior-sso-facebook:hover {
  background: #166FE0;
  color: #ffffff;
  border-color: transparent;
}
.aior-reg-sso .aior-sso-google {
  background: #ffffff;
  color: #1f2328;
  border: 1px solid #d0d7de;
}
.aior-reg-sso .aior-sso-google:hover {
  background: #f6f8fa;
  color: #1f2328;
  border-color: #d0d7de;
}
.aior-reg-sso .aior-sso-twitter,
.aior-reg-sso .aior-sso-x {
  background: #1DA1F2;
  color: #ffffff;
}
.aior-reg-sso .aior-sso-twitter:hover,
.aior-reg-sso .aior-sso-x:hover {
  background: #1991DA;
  color: #ffffff;
  border-color: transparent;
}
/* Brand-colored SSO buttons need white icons (icon defaults are brand-color
   on transparent bg — invisible on solid same-color bg). */
.aior-reg-sso .aior-sso-facebook .aior-sso-icon {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M24 12.073C24 5.405 18.627 0 12 0S0 5.405 0 12.073c0 6.019 4.388 11.011 10.125 11.927v-8.437H7.078v-3.49h3.047V9.413c0-3.014 1.792-4.679 4.532-4.679 1.313 0 2.686.235 2.686.235v2.965h-1.514c-1.491 0-1.956.93-1.956 1.886v2.263h3.328l-.532 3.49h-2.796V24C19.612 23.084 24 18.092 24 12.073z'/></svg>");
}
.aior-reg-sso .aior-sso-twitter .aior-sso-icon,
.aior-reg-sso .aior-sso-x .aior-sso-icon {
  /* Classic Twitter bird icon (matches reference screenshot — light blue brand) */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23ffffff' d='M22.46 6c-.77.35-1.6.58-2.46.69.88-.53 1.56-1.37 1.88-2.38-.83.5-1.75.85-2.72 1.05C18.37 4.5 17.26 4 16 4c-2.35 0-4.27 1.92-4.27 4.29 0 .34.04.67.11.98C8.28 9.09 5.11 7.38 3 4.79c-.37.63-.58 1.37-.58 2.15 0 1.49.75 2.81 1.91 3.56-.71 0-1.37-.2-1.95-.5v.03c0 2.08 1.48 3.82 3.44 4.21a4.22 4.22 0 0 1-1.93.07 4.28 4.28 0 0 0 4 2.98 8.521 8.521 0 0 1-5.33 1.84c-.34 0-.68-.02-1.02-.06C3.44 20.29 5.7 21 8.12 21 16 21 20.33 14.46 20.33 8.79c0-.19 0-.37-.01-.56.84-.6 1.56-1.36 2.14-2.23z'/></svg>");
}

/* Fix grids that may have been declared without the parent .aior-grid class —
   inside register cards, force grid display so 2/3-col layouts apply. */
.aior-reg-card .aior-grid-2,
.aior-reg-card .aior-grid-3,
.aior-reg-card .aior-grid-4 {
  display: grid;
  gap: 14px;
}
.aior-reg-card .aior-grid-2 { grid-template-columns: repeat(1, 1fr); }
.aior-reg-card .aior-grid-3 { grid-template-columns: repeat(1, 1fr); }
@media (min-width: 640px) {
  .aior-reg-card .aior-grid-2 { grid-template-columns: repeat(2, 1fr); }
  .aior-reg-card .aior-grid-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .aior-reg-card .aior-grid-3 { grid-template-columns: repeat(3, 1fr); }
}
.aior-reg-card .aior-stack-sm {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Section heading — integrated into top of card via overlap.
   The h2 sits ABOVE the card with a slight downward overlap so the
   "nested" feel is achieved (heading visually merges with card top). */
.aior-reg-heading {
  position: relative;
  margin: 0 0 -1px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--fg);
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 12%, var(--bg-soft)) 0%, var(--bg-soft) 70%);
  border: 1px solid var(--line);
  border-radius: 12px 12px 0 0;
  border-bottom-color: color-mix(in srgb, var(--accent) 25%, var(--line));
}
.aior-reg-heading::before {
  content: "";
  flex: 0 0 4px;
  width: 4px;
  height: 18px;
  background: linear-gradient(180deg, var(--accent), var(--accent-deep));
  border-radius: 4px;
  box-shadow: 0 0 12px -2px var(--accent);
}
.aior-reg-heading > span { flex: 1 1 auto; }

/* Card sits flush below heading (no top radius) — they merge into one block */
.aior-reg-card {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-top-color: var(--line);
  border-radius: 0 0 12px 12px;
  padding: 20px;
  /* subtle inner glow on left to echo the accent strip in heading */
  box-shadow: inset 2px 0 0 -1px color-mix(in srgb, var(--accent) 18%, transparent);
}
@media (min-width: 640px) {
  .aior-reg-card { padding: 22px 24px; }
}
.aior-reg-card .aior-input {
  background: var(--bg-sunken, var(--bg));
  border: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
  transition: border-color 160ms, background 160ms, box-shadow 160ms;
}
.aior-reg-card .aior-input:hover {
  border-color: var(--line-strong);
  background: var(--bg);
}
.aior-reg-card .aior-input:focus {
  border-color: var(--accent);
  background: var(--bg);
  box-shadow: 0 0 0 3px var(--accent-ring, rgba(74,182,245,0.18));
  outline: none;
}
/* Accent-tinted icons inside register card inputs */
.aior-reg-card .aior-input-icon {
  color: color-mix(in srgb, var(--accent) 70%, var(--fg-muted));
  transition: color 160ms;
}
.aior-reg-card .aior-input-wrap:focus-within .aior-input-icon {
  color: var(--accent);
}

/* AIOR Phone Country Code Widget — custom dropdown (no external library).
   Reference: Croster's intl-tel-input UX with TR flag + dial code button. */
.aior-phone-field {
  position: relative;
  display: flex;
  align-items: stretch;
  width: 100%;
  background: var(--bg-sunken, var(--bg));
  border: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
  border-radius: var(--r-md);
  transition: border-color 160ms, box-shadow 160ms;
}
.aior-phone-field:hover { border-color: var(--line-strong); }
.aior-phone-field:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring, rgba(74,182,245,0.18));
}
.aior-phone-cc-btn {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 44px;
  padding: 0 10px 0 12px;
  background: transparent;
  border: 0;
  border-right: 1px solid var(--line);
  color: var(--fg);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
}
.aior-phone-cc-flag { font-size: 18px; line-height: 1; }
.aior-phone-cc-code { letter-spacing: -0.005em; }
.aior-phone-cc-caret {
  font-size: 10px;
  color: var(--fg-muted);
  margin-left: 2px;
  transition: transform 160ms;
}
.aior-phone-cc-btn[aria-expanded="true"] .aior-phone-cc-caret { transform: rotate(180deg); }

.aior-phone-input {
  flex: 1 1 auto;
  min-width: 0;
  height: 44px;
  padding: 0 14px;
  background: transparent !important;
  border: 0 !important;
  color: var(--fg);
  font-size: 14px;
  outline: none;
}
.aior-phone-input:focus { box-shadow: none !important; }

/* Dropdown panel */
.aior-phone-cc-list {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 50;
  width: max(360px, 100%);
  max-width: 540px;
  max-height: 320px;
  overflow-y: auto;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 6px 0;
  box-shadow: 0 12px 32px -8px rgba(0,0,0,0.45);
}
.aior-phone-cc-list[hidden] { display: none; }
.aior-phone-cc-sep {
  height: 1px;
  background: var(--line);
  margin: 6px 12px;
}
.aior-phone-cc-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 8px 14px;
  background: transparent;
  border: 0;
  color: var(--fg);
  font-size: 14px;
  text-align: left;
  cursor: pointer;
  transition: background 120ms;
}
.aior-phone-cc-item:hover,
.aior-phone-cc-item:focus-visible {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--fg);
  outline: none;
}
.aior-phone-cc-item > span:first-child { font-size: 18px; line-height: 1; flex: 0 0 auto; }
.aior-phone-cc-item > span:nth-child(2) { flex: 1 1 auto; }
.aior-phone-cc-item > em {
  flex: 0 0 auto;
  font-style: normal;
  color: var(--fg-muted);
  font-size: 13px;
  letter-spacing: -0.005em;
}
/* Custom scrollbar inside dropdown */
.aior-phone-cc-list::-webkit-scrollbar { width: 6px; }
.aior-phone-cc-list::-webkit-scrollbar-thumb {
  background: var(--line-strong);
  border-radius: 3px;
}

/* Override the .aior-reg-card .aior-input rules — phone widget is its own
   container, the inner input shouldn't get the card's input border styles */
.aior-reg-card .aior-phone-field .aior-phone-input {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Mailing list toggle switch */
.aior-mailing-content { display: flex; flex-direction: column; gap: 16px; }
.aior-mailing-desc {
  margin: 0;
  font-size: 13.5px;
  color: var(--fg-soft);
  line-height: 1.55;
}
.aior-toggle {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--bg-sunken, var(--bg));
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  cursor: pointer;
  font-size: 14px;
  color: var(--fg);
  align-self: flex-start;
}
.aior-toggle-switch {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 26px;
  flex-shrink: 0;
}
.aior-toggle-switch input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
  pointer-events: none;
}
.aior-toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--line-strong);
  border-radius: 999px;
  transition: background 200ms;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.aior-toggle-slider::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  background: #ffffff;
  border-radius: 50%;
  transition: transform 200ms;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.aior-toggle-on,
.aior-toggle-off {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #ffffff;
  padding: 0 8px;
  user-select: none;
}
.aior-toggle-on { display: none; padding-right: 26px; }
.aior-toggle-off { display: inline-block; padding-left: 26px; }
.aior-toggle-switch input[type="checkbox"]:checked + .aior-toggle-slider {
  background: var(--accent);
  justify-content: flex-start;
}
.aior-toggle-switch input[type="checkbox"]:checked + .aior-toggle-slider::before {
  transform: translateX(34px);
}
.aior-toggle-switch input[type="checkbox"]:checked + .aior-toggle-slider .aior-toggle-on { display: inline-block; }
.aior-toggle-switch input[type="checkbox"]:checked + .aior-toggle-slider .aior-toggle-off { display: none; }
.aior-toggle-switch input[type="checkbox"]:focus-visible + .aior-toggle-slider {
  box-shadow: 0 0 0 3px var(--accent-ring, rgba(74,182,245,0.3));
}

/* Password meter / generate row */
.aior-pw-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.aior-pw-row .aior-btn {
  flex: 0 0 auto;
  height: 36px;
  padding: 0 14px;
  font-size: 13px;
  border-radius: var(--r-md);
}
.aior-pw-meter {
  flex: 1 1 240px;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.aior-pw-meter-bar {
  height: 2px;
  background: var(--accent);
  border-radius: 2px;
  transition: width 200ms;
  box-shadow: 0 0 0 1px var(--line);
}
.aior-pw-meter-label {
  margin: 0;
  font-size: 12px;
  text-align: right;
  color: var(--fg-muted);
}

/* "Already registered?" section — existing-customer prompt with 2 actions */
.aior-reg-existing {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.aior-reg-existing-desc {
  margin: 0;
  font-size: 14px;
  color: var(--fg-soft);
  line-height: 1.6;
}
.aior-reg-existing-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.aior-reg-existing-btn {
  height: 42px;
  padding: 0 22px;
  font-size: 13.5px;
  font-weight: 500;
  border-radius: var(--r-md);
  text-decoration: none;
}
.aior-reg-existing-btn.aior-btn-ghost {
  background: transparent;
  color: var(--fg);
  border: 1px solid var(--line);
}
.aior-reg-existing-btn.aior-btn-ghost:hover {
  background: var(--bg);
  border-color: var(--line-strong);
  color: var(--fg);
}

/* Bottom actions row */
.aior-reg-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  margin-top: 32px;
}
.aior-reg-submit {
  height: 44px;
  padding: 0 28px;
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--r-md);
}

/* Custom field input compatibility — make WHMCS-injected inputs match aior-input */
.aior-reg-card .aior-field input:not(.aior-input):not([type="hidden"]),
.aior-reg-card .aior-field select:not(.aior-input):not(.aior-records-select),
.aior-reg-card .aior-field textarea:not(.aior-input) {
  width: 100%;
  height: 44px;
  padding: 0 14px;
  font: inherit;
  font-size: 14px;
  color: var(--fg);
  background: var(--bg-sunken, var(--bg));
  border: 1px solid transparent;
  border-radius: var(--r-md);
  transition: border-color 160ms;
}

/* Table primitives */
.aior-table { border-collapse: separate; border-spacing: 0; font-size: 14px; color: var(--fg); width: 100%; }
.aior-table thead th {
  text-align: left;
  padding: 12px 16px;
  font-size: 11.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--fg-muted);
  border-bottom: 1px solid var(--line);
  background: transparent;
}
.aior-table tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
  vertical-align: middle;
}
.aior-table tbody tr:last-child td { border-bottom: 0; }
.aior-table-rows tbody tr { transition: background 160ms; }
.aior-table-rows tbody tr:hover { background: var(--bg-soft); }
.aior-row-link { cursor: pointer; }

/* Pagination */
.aior-pagination { display: flex; flex-wrap: wrap; gap: 4px; justify-content: center; margin: 24px 0; }
.aior-pagination-item {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px;
  padding: 0 12px;
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--fg-soft);
  font-size: 13px; font-weight: 500;
  text-decoration: none;
  border: 1px solid var(--line);
  transition: background 160ms, border-color 160ms, color 160ms;
}
.aior-pagination-item:hover { background: var(--bg-soft); border-color: var(--line-strong); color: var(--fg); }
.aior-pagination-item.is-active { background: var(--accent); border-color: var(--accent); color: var(--fg-on-accent); }
.aior-pagination-item.is-disabled { opacity: 0.4; pointer-events: none; }

/* Announcement */
.aior-announcement-title {
  display: block;
  font-size: 20px; font-weight: 700; letter-spacing: -0.01em;
  color: var(--fg); text-decoration: none;
  margin: 0 0 8px; transition: color 160ms;
}
.aior-announcement-title:hover { color: var(--accent-deep); }
.aior-announcement-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 12px;
  margin: 0 0 14px;
  font-size: 12.5px; color: var(--fg-muted);
}
.aior-announcement-meta i { color: var(--fg-faint); }
.aior-announcement-body { font-size: 14.5px; line-height: 1.65; color: var(--fg-soft); }
.aior-announcement-detail .aior-announcement-meta {
  margin-bottom: 18px; padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}

/* Search pill */
.aior-search-pill {
  display: flex; align-items: center; gap: 0;
  padding: 6px 6px 6px 16px;
  border-radius: 999px;
  background: var(--bg);
  border: 1px solid var(--line);
  transition: border-color 160ms, box-shadow 160ms;
}
.aior-search-pill:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-ring); }
.aior-search-icon { color: var(--fg-muted); font-size: 14px; flex-shrink: 0; }
.aior-search-input {
  flex: 1; border: 0; outline: 0;
  background: transparent;
  padding: 8px 12px;
  font: inherit; font-size: 14.5px;
  color: var(--fg);
  min-width: 0;
}
.aior-search-input::placeholder { color: var(--fg-faint); }
.aior-kb-search { margin: 0 0 8px; }

/* KB cat / article */
.aior-kb-cat { display: flex; gap: 14px; align-items: flex-start; text-decoration: none; color: var(--fg); position: relative; }
.aior-kb-cat-icon {
  width: 44px; height: 44px;
  border-radius: var(--r-sm);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent-deep);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.aior-kb-cat-body { flex: 1; min-width: 0; }
.aior-kb-cat-title {
  font-size: 15px; font-weight: 700; letter-spacing: -0.005em;
  color: var(--fg); margin: 0;
  display: flex; align-items: center; flex-wrap: wrap; gap: 6px;
}
.aior-kb-articles { list-style: none; margin: 0; padding: 0; }
.aior-kb-article-row {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
}
.aior-kb-article-row:last-child { border-bottom: 0; }
.aior-kb-article-link { display: flex; align-items: flex-start; gap: 12px; text-decoration: none; color: var(--fg); flex: 1; min-width: 0; }
.aior-kb-article-link i { color: var(--accent-deep); margin-top: 3px; flex-shrink: 0; }
.aior-kb-article-title {
  display: block;
  font-size: 14.5px; font-weight: 600; letter-spacing: -0.005em;
  color: var(--fg); transition: color 160ms;
}
.aior-kb-article-link:hover .aior-kb-article-title { color: var(--accent-deep); }
.aior-kb-article-header {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 14px;
  margin-bottom: 18px; padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.aior-kb-article .aior-kb-article-title { font-size: 26px; line-height: 1.15; letter-spacing: -0.015em; margin: 0; color: var(--fg); }
.aior-kb-article-content { font-size: 15px; line-height: 1.7; color: var(--fg); }
.aior-kb-article-content h2,
.aior-kb-article-content h3,
.aior-kb-article-content h4 { margin: 28px 0 12px; color: var(--fg); }
.aior-kb-article-content p { margin: 0 0 14px; }
.aior-kb-article-content code, .aior-kb-article-content pre {
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-size: 13px; background: var(--bg-soft); padding: 2px 6px; border-radius: 4px;
}
.aior-kb-article-content pre { padding: 14px 18px; overflow-x: auto; line-height: 1.55; }
.aior-kb-article-meta {
  list-style: none; margin: 24px 0 0;
  padding: 14px 0 0;
  border-top: 1px solid var(--line);
  display: flex; flex-wrap: wrap; gap: 18px;
  font-size: 12.5px; color: var(--fg-muted);
}
.aior-kb-article-meta li { display: flex; align-items: center; gap: 6px; }
.aior-kb-rate { margin-top: 24px; padding: 16px 18px; background: var(--bg-soft); border-radius: var(--r-md); }
.aior-kb-rate-form { margin: 0; }

/* Ticket detail + thread */
.aior-ticket-info { padding: 18px 22px; }
.aior-ticket-info-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px 24px; font-size: 14px; }
@media (min-width: 768px) { .aior-ticket-info-grid { grid-template-columns: repeat(4, 1fr); } }

.aior-collapsible { padding: 0; overflow: hidden; }
.aior-collapsible-summary {
  list-style: none; cursor: pointer;
  padding: 16px 22px;
  display: flex; align-items: center; gap: 10px;
  font-weight: 600; color: var(--fg);
  user-select: none;
  background: var(--bg-soft);
  border-bottom: 1px solid transparent;
  transition: background 160ms;
}
.aior-collapsible-summary::-webkit-details-marker { display: none; }
.aior-collapsible-summary i { color: var(--accent-deep); }
.aior-collapsible-summary::after { content: "+"; margin-left: auto; font-size: 18px; font-weight: 700; color: var(--fg-muted); transition: transform 160ms; }
.aior-collapsible[open] .aior-collapsible-summary { background: var(--bg); border-bottom-color: var(--line); }
.aior-collapsible[open] .aior-collapsible-summary::after { content: "−"; }
.aior-collapsible > *:not(.aior-collapsible-summary) { padding: 22px; }

.aior-ticket-thread { display: flex; flex-direction: column; gap: 14px; }
.aior-ticket-reply { border-left: 3px solid var(--line); }
.aior-ticket-reply--staff {
  border-left-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 4%, var(--bg));
}
.aior-ticket-reply-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 14px;
  margin-bottom: 14px; padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.aior-ticket-reply-author { display: flex; gap: 12px; align-items: flex-start; }
.aior-ticket-reply-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--bg-soft);
  color: var(--fg-muted);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  border: 1px solid var(--line);
}
.aior-ticket-reply-avatar[data-staff="true"] {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent-deep);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
}
.aior-ticket-reply-body { font-size: 14.5px; line-height: 1.65; color: var(--fg); }
.aior-ticket-reply-body p { margin: 0 0 10px; }
.aior-ticket-reply-attachments {
  margin-top: 14px; padding-top: 14px;
  border-top: 1px solid var(--line);
  font-size: 13.5px;
}
.aior-ticket-reply-attachments ul { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.aior-ticket-reply-attachments li { display: flex; align-items: center; gap: 8px; }

/* Product hero */
.aior-product-hero { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 28px 22px; }
.aior-product-hero-icon {
  width: 72px; height: 72px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 28px; margin-bottom: 16px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-deep);
}
.aior-product-status-active   .aior-product-hero-icon { background: color-mix(in srgb, #16a34a 14%, transparent); color: #16a34a; }
.aior-product-status-pending  .aior-product-hero-icon { background: color-mix(in srgb, #ea580c 14%, transparent); color: #ea580c; }
.aior-product-status-suspended .aior-product-hero-icon,
.aior-product-status-cancelled .aior-product-hero-icon,
.aior-product-status-terminated .aior-product-hero-icon {
  background: color-mix(in srgb, #dc2626 14%, transparent);
  color: #dc2626;
}
.aior-product-hero-title { margin: 0; font-size: 22px; font-weight: 700; letter-spacing: -0.015em; color: var(--fg); }

/* Tabs */
.aior-tabs { width: 100%; }
.aior-tab-nav {
  display: flex; flex-wrap: wrap; gap: 2px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 18px;
  overflow-x: auto;
}
.aior-tab-link {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 16px;
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  color: var(--fg-muted);
  font-size: 13.5px; font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: color 160ms, border-color 160ms;
}
.aior-tab-link:hover { color: var(--fg); }
.aior-tab-link.is-active { color: var(--accent-deep); border-bottom-color: var(--accent); font-weight: 600; }
.aior-tab-panels { width: 100%; }
.aior-tab-panel { display: none; }
.aior-tab-panel.is-active { display: block; animation: aiorTabFade 200ms ease; }
@keyframes aiorTabFade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

/* Alert row */
.aior-alert-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  border-left: 4px solid var(--accent);
}
.aior-alert-row > i { font-size: 20px; flex-shrink: 0; }
.aior-alert-warning { background: color-mix(in srgb, #f59e0b 8%, transparent); border-left-color: #f59e0b; }
.aior-alert-warning > i { color: #f59e0b; }
.aior-alert-danger  { background: color-mix(in srgb, #dc2626 8%, transparent); border-left-color: #dc2626; }
.aior-alert-danger > i { color: #dc2626; }
.aior-alert-success { background: color-mix(in srgb, #16a34a 8%, transparent); border-left-color: #16a34a; }
.aior-alert-success > i { color: #16a34a; }
.aior-alert-info    { background: color-mix(in srgb, var(--accent) 8%, transparent); border-left-color: var(--accent); }
.aior-alert-info > i { color: var(--accent-deep); }

/* Card head/body/foot */
.aior-card-head {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-bottom: 14px; padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.aior-card-title {
  margin: 0;
  font-size: 15px; font-weight: 600;
  color: var(--fg);
  display: flex; align-items: center; gap: 8px;
}
.aior-card-title i { color: var(--accent-deep); }
.aior-card-foot { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); }

/* Field */
.aior-field { display: flex; flex-direction: column; gap: 6px; }
.aior-input-wrap { position: relative; display: flex; align-items: center; }
.aior-input-icon { position: absolute; left: 14px; color: var(--fg-muted); pointer-events: none; }
.aior-input-wrap .aior-input { padding-left: 38px; }

/* Badge */
.aior-badge {
  display: inline-flex; align-items: center;
  padding: 1px 7px;
  border-radius: 999px;
  font-size: 11px; font-weight: 600;
  background: var(--bg-soft);
  color: var(--fg-soft);
}
.aior-badge-brand {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent-deep);
}

.aior-btn-soft {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-deep);
}
.aior-btn-soft:hover {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--accent-deep);
}

/* Generic alert */
.aior-alert { display: flex; gap: 12px; padding: 12px 16px; border-radius: var(--r-md); font-size: 14px; margin: 14px 0; }
.aior-alert > i { font-size: 18px; flex-shrink: 0; margin-top: 2px; }
.aior-alert-error, .aior-alert.aior-alert-error { background: color-mix(in srgb, #dc2626 8%, transparent); color: #dc2626; }

/* Marketing optin */
.aior-marketing-optin {
  background: color-mix(in srgb, var(--accent) 6%, transparent);
  border-color: color-mix(in srgb, var(--accent) 20%, var(--line));
}

/* ============================================================
   3. BOOTSTRAP-CLASS COMPATIBILITY SHIM (WHMCS templates use these)
   ============================================================ */

/* Modals — hidden by default */
.modal {
  display: none;
  position: fixed;
  top: 0; right: 0; bottom: 0; left: 0;
  z-index: 1050;
  overflow-x: hidden; overflow-y: auto;
  outline: 0;
}
.modal.in, .modal.show, .modal[style*="display: block"] { display: block; }
.modal-dialog { position: relative; width: auto; margin: 30px auto; max-width: 560px; }
.modal-content {
  position: relative;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: 0 32px 80px -28px rgba(15, 23, 42, 0.3);
  outline: 0;
  color: var(--fg);
}
.modal-header { padding: 16px 22px; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; }
.modal-header .close { background: transparent; border: 0; font-size: 22px; line-height: 1; color: var(--fg-muted); cursor: pointer; padding: 0; }
.modal-title { margin: 0; font-size: 16px; font-weight: 600; color: var(--fg); }
.modal-body { padding: 18px 22px; color: var(--fg); }
.modal-footer {
  padding: 14px 22px;
  border-top: 1px solid var(--line);
  display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: 8px;
}
.modal-backdrop { position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 1040; background: rgba(0, 0, 0, 0.6); }
.modal-backdrop.fade { opacity: 0; transition: opacity 200ms; }
.modal-backdrop.in, .modal-backdrop.show { opacity: 1; }
body.modal-open { overflow: hidden; padding-right: 0 !important; }

/* 12-col grid */
.row { display: flex; flex-wrap: wrap; margin-left: -12px; margin-right: -12px; }
.row > [class*="col-"] { padding-left: 12px; padding-right: 12px; flex: 0 0 auto; max-width: 100%; }
.col-12 { width: 100%; }
.col-xs-12 { width: 100%; }
.col-xs-11 { width: 91.6667%; }
.col-xs-10 { width: 83.3333%; }
.col-xs-9  { width: 75%; }
.col-xs-8  { width: 66.6667%; }
.col-xs-7  { width: 58.3333%; }
.col-xs-6  { width: 50%; }
.col-xs-5  { width: 41.6667%; }
.col-xs-4  { width: 33.3333%; }
.col-xs-3  { width: 25%; }
.col-xs-2  { width: 16.6667%; }
.col-xs-1  { width: 8.3333%; }
.col-xs-offset-1 { margin-left: 8.3333%; }
.col-xs-offset-2 { margin-left: 16.6667%; }
.col-xs-offset-3 { margin-left: 25%; }
.col-xs-offset-4 { margin-left: 33.3333%; }
.col-xs-offset-5 { margin-left: 41.6667%; }
.col-xs-offset-6 { margin-left: 50%; }
@media (min-width: 768px) {
  .col-sm-12 { width: 100%; }
  .col-sm-11 { width: 91.6667%; }
  .col-sm-10 { width: 83.3333%; }
  .col-sm-9  { width: 75%; }
  .col-sm-8  { width: 66.6667%; }
  .col-sm-7  { width: 58.3333%; }
  .col-sm-6  { width: 50%; }
  .col-sm-5  { width: 41.6667%; }
  .col-sm-4  { width: 33.3333%; }
  .col-sm-3  { width: 25%; }
  .col-sm-2  { width: 16.6667%; }
  .col-sm-1  { width: 8.3333%; }
  .col-sm-offset-1 { margin-left: 8.3333%; }
  .col-sm-offset-2 { margin-left: 16.6667%; }
  .col-sm-offset-3 { margin-left: 25%; }
  .col-sm-offset-4 { margin-left: 33.3333%; }
  .col-sm-offset-5 { margin-left: 41.6667%; }
  .col-sm-offset-6 { margin-left: 50%; }
}
@media (min-width: 992px) {
  .col-md-12 { width: 100%; }
  .col-md-11 { width: 91.6667%; }
  .col-md-10 { width: 83.3333%; }
  .col-md-9  { width: 75%; }
  .col-md-8  { width: 66.6667%; }
  .col-md-7  { width: 58.3333%; }
  .col-md-6  { width: 50%; }
  .col-md-5  { width: 41.6667%; }
  .col-md-4  { width: 33.3333%; }
  .col-md-3  { width: 25%; }
  .col-md-2  { width: 16.6667%; }
  .col-md-1  { width: 8.3333%; }
}

/* Panel / Card (Bootstrap-style) */
.panel,
.card:not(.aior-card) {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  margin-bottom: 18px;
  color: var(--fg);
}
.panel-heading, .card-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  background: transparent;
  font-weight: 600;
  color: var(--fg);
}
.panel-body, .card-body { padding: 18px; color: var(--fg); }
.panel-footer, .card-footer {
  padding: 14px 18px;
  background: var(--bg);
  border-top: 1px solid var(--line);
  border-bottom-left-radius: var(--r-md);
  border-bottom-right-radius: var(--r-md);
  color: var(--fg-soft);
}
.panel-title, .card-title { margin: 0; font-size: 15px; font-weight: 600; color: var(--fg); }

/* List groups */
.list-group { list-style: none; margin: 0; padding: 0; border-radius: var(--r-md); overflow: hidden; }
.list-group-item {
  display: block;
  padding: 12px 16px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
  color: var(--fg-soft);
  background: transparent;
  text-decoration: none;
  font-size: 13.5px; font-weight: 500;
  transition: background 160ms, color 160ms;
}
.list-group-item:last-child { border-bottom: 0; }
.list-group-item:hover, .list-group-item-action:hover { background: var(--bg); color: var(--fg); }
.list-group-item.active { background: color-mix(in srgb, var(--accent) 14%, transparent); color: var(--accent-deep); font-weight: 600; }

/* WHMCS-only Bootstrap button variants — extend canonical .btn */
.btn-default,
.btn-secondary {
  background: var(--bg-soft);
  color: var(--fg);
  border: 1px solid var(--line);
}
.btn-default:hover, .btn-secondary:hover { background: var(--bg); border-color: var(--line-strong); }
.btn-success { background: #16a34a; color: #fff; border: 0; }
.btn-success:hover { background: #15803d; }
.btn-danger  { background: #dc2626; color: #fff; border: 0; }
.btn-danger:hover  { background: #b91c1c; }
.btn-warning { background: #f59e0b; color: #fff; border: 0; }
.btn-warning:hover { background: #d97706; }
.btn-info    { background: var(--accent); color: var(--fg-on-accent); border: 0; }
.btn-info:hover    { background: var(--accent-deep); }
.btn-link {
  background: transparent;
  border: 0;
  color: var(--accent-deep);
  padding: 6px 8px;
}
.btn-link:hover { color: var(--accent); text-decoration: underline; background: transparent; }
.btn-block { display: block; width: 100%; }
.btn-sm, .btn-xs { height: auto; padding: 6px 10px; font-size: 12.5px; }
.btn-lg { height: auto; padding: 11px 18px; font-size: 15px; }

/* Form controls */
.form-control,
input[type="text"]:not(.aior-input):not([type="hidden"]),
input[type="email"]:not(.aior-input),
input[type="password"]:not(.aior-input),
input[type="tel"]:not(.aior-input),
input[type="number"]:not(.aior-input),
input[type="url"]:not(.aior-input),
input[type="search"]:not(.aior-input),
select:not(.aior-input):not(.aior-records-select),
textarea:not(.aior-textarea) {
  width: 100%;
  height: 40px;
  padding: 8px 12px;
  font: inherit;
  font-size: 14px;
  color: var(--fg);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  outline: 0;
  transition: border-color 160ms, box-shadow 160ms;
}
textarea.form-control,
textarea:not(.aior-textarea) { height: auto; min-height: 88px; padding: 12px; resize: vertical; }
.form-control:focus,
input[type="text"]:focus:not(.aior-input):not([type="hidden"]),
input[type="email"]:focus:not(.aior-input),
input[type="password"]:focus:not(.aior-input),
input[type="tel"]:focus:not(.aior-input),
input[type="number"]:focus:not(.aior-input),
input[type="url"]:focus:not(.aior-input),
input[type="search"]:focus:not(.aior-input),
select:focus:not(.aior-input),
textarea:focus:not(.aior-textarea) {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}
.form-control::placeholder { color: var(--fg-faint); }
.form-group { margin-bottom: 14px; }
.control-label { display: block; margin-bottom: 6px; font-size: 12.5px; font-weight: 600; color: var(--fg-soft); }
.help-block { margin-top: 6px; font-size: 12px; color: var(--fg-muted); }
.input-group { position: relative; display: flex; align-items: stretch; width: 100%; }
.input-group > .form-control { flex: 1; min-width: 0; }
.input-group-btn { display: inline-flex; }
.input-group-lg .form-control { height: 48px; font-size: 15px; }

/* Alerts */
.alert {
  padding: 14px 18px;
  border: 0;
  border-left: 4px solid;
  border-radius: var(--r-md);
  margin: 14px 0;
  font-size: 14px;
  background: var(--bg-soft);
  color: var(--fg);
}
.alert-danger,  .alert-error { background: color-mix(in srgb, #dc2626 8%, transparent); border-left-color: #dc2626; }
.alert-warning { background: color-mix(in srgb, #f59e0b 8%, transparent); border-left-color: #f59e0b; }
.alert-success { background: color-mix(in srgb, #16a34a 8%, transparent); border-left-color: #16a34a; }
.alert-info    { background: color-mix(in srgb, var(--accent) 8%, transparent); border-left-color: var(--accent); }

/* Tables */
.table { width: 100%; margin-bottom: 18px; border-collapse: separate; border-spacing: 0; background: transparent; color: var(--fg); }
.table th {
  border-bottom: 1px solid var(--line);
  color: var(--fg-muted);
  font-size: 11.5px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 12px 16px; text-align: left;
}
.table td { border-top: 1px solid color-mix(in srgb, var(--line) 60%, transparent); color: var(--fg); padding: 14px 16px; vertical-align: middle; }
.table-striped > tbody > tr:nth-of-type(odd) { background: var(--bg-soft); }
.table-hover > tbody > tr:hover { background: var(--bg); }
.table-bordered { border: 1px solid var(--line); }
.table-bordered td, .table-bordered th { border: 1px solid var(--line); }

/* Tabs */
.nav-tabs { list-style: none; margin: 0 0 18px; padding: 0; display: flex; flex-wrap: wrap; border-bottom: 1px solid var(--line); }
.nav-tabs > li { display: inline-block; }
.nav-tabs > li > a {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 12px 16px;
  background: transparent;
  border-bottom: 2px solid transparent;
  color: var(--fg-muted);
  font-size: 13.5px; font-weight: 500;
  text-decoration: none;
  transition: color 160ms, border-color 160ms;
}
.nav-tabs > li > a:hover { color: var(--fg); }
.nav-tabs > li.active > a { color: var(--accent-deep); border-bottom-color: var(--accent); font-weight: 600; }
.tab-content > .tab-pane { display: none; }
.tab-content > .tab-pane.active, .tab-content > .tab-pane.in, .tab-content > .tab-pane.show { display: block; }

/* Dropdowns */
.dropdown { position: relative; display: inline-block; }
.dropdown-menu {
  position: absolute;
  top: 100%; left: 0;
  z-index: 1000;
  display: none;
  min-width: 180px;
  padding: 6px;
  margin: 4px 0 0;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: 0 12px 32px -12px rgba(15, 23, 42, 0.18);
  list-style: none;
}
.dropdown-menu.show, .dropdown.open > .dropdown-menu, .btn-group.open > .dropdown-menu { display: block; }
.dropdown-menu > li { display: block; }
.dropdown-menu > li > a {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  border-radius: var(--r-sm);
  color: var(--fg-soft);
  text-decoration: none;
  font-size: 13.5px;
}
.dropdown-menu > li > a:hover { background: var(--bg); color: var(--fg); }
.dropdown-menu .divider { height: 1px; background: var(--line); margin: 6px 0; }
.dropdown-menu-right { right: 0; left: auto; }
.btn-group { position: relative; display: inline-flex; }
.caret { display: inline-block; margin-left: 4px; border: 4px solid transparent; border-top-color: currentColor; vertical-align: middle; }

/* Misc utilities */
.text-muted { color: var(--fg-muted); }
.text-primary { color: var(--accent-deep); }
.text-success { color: #16a34a; }
.text-danger  { color: #dc2626; }
.text-warning { color: #f59e0b; }
.text-info    { color: var(--accent-deep); }
.text-center { text-align: center; }
.text-right  { text-align: right; }
.text-left   { text-align: left; }
.pull-right, .float-right { float: right; }
.pull-left, .float-left   { float: left; }
.clearfix::after { content: ""; display: table; clear: both; }
[hidden] { display: none; }
.visible-print-block { display: none; }
@media print { .visible-print-block { display: block; } .hidden-print { display: none !important; } }
.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;
}
.margin-bottom { margin-bottom: 18px; }
.margin-top { margin-top: 18px; }
.no-border { border: 0 !important; }
.text-uppercase { text-transform: uppercase; }

/* ============================================================
   4. CART PAGE (aior_cart order form)
   ============================================================ */

.aior-cart-page { display: block; }
.aior-cart-header { margin-bottom: 24px; }
.aior-cart-title {
  margin: 0 0 6px;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--fg);
}
.aior-cart-subtitle { margin: 0; font-size: 14px; color: var(--fg-muted); line-height: 1.55; }

.aior-cart-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .aior-cart-grid { grid-template-columns: 1fr 320px; align-items: flex-start; }
}
.aior-cart-items-col { min-width: 0; display: flex; flex-direction: column; gap: 18px; }
.aior-cart-summary-col { min-width: 0; }
@media (min-width: 1024px) {
  .aior-cart-summary { position: sticky; top: 100px; }
}

/* Cart items header (column labels) */
.aior-cart-items-header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 12px 16px 12px;
  border-bottom: 1px solid var(--line);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.aior-cart-items-header > .aior-text-right,
.aior-cart-items-header > .aior-text-center { white-space: nowrap; }

/* Cart items list */
.aior-cart-items {
  list-style: none;
  margin: 0;
  padding: 0;
}
.aior-cart-item {
  display: grid;
  grid-template-columns: 1fr auto 28px;
  gap: 14px;
  padding: 16px 16px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
  align-items: flex-start;
}
@media (max-width: 640px) {
  .aior-cart-item { grid-template-columns: 1fr 28px; }
  .aior-cart-item-price { grid-column: 1 / 2; }
  .aior-cart-item-qty { grid-column: 1 / 2; }
}
.aior-cart-item:last-child { border-bottom: 0; }
.aior-cart-item-addon { padding-left: 36px; background: color-mix(in srgb, var(--accent) 3%, transparent); }
.aior-cart-item-credit { background: color-mix(in srgb, #16a34a 5%, transparent); }

.aior-cart-item-info { min-width: 0; }
.aior-cart-item-title {
  display: flex; align-items: baseline; flex-wrap: wrap; gap: 8px;
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 600;
  color: var(--fg);
}
.aior-cart-item-edit { font-size: 12px; font-weight: 500; }
.aior-cart-item-meta {
  margin: 0 0 4px;
  font-size: 12.5px;
  color: var(--fg-muted);
  letter-spacing: 0.02em;
}
.aior-cart-item-domain {
  margin: 4px 0;
  font-size: 13px;
  color: var(--accent-deep);
}
.aior-cart-item-options {
  list-style: none;
  margin: 6px 0 0;
  padding: 0;
  font-size: 12.5px;
  color: var(--fg-soft);
}
.aior-cart-item-options li { padding: 1px 0; }
.aior-cart-item-options li::before { content: "» "; color: var(--fg-faint); }

.aior-cart-item-qty {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
  width: 90px;
}
.aior-cart-item-qty .aior-input { width: 70px; height: 32px; padding: 4px 8px; font-size: 13px; }

.aior-cart-item-price {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  text-align: right;
  white-space: nowrap;
}
.aior-cart-item-price strong { font-size: 15px; color: var(--fg); }
.aior-cart-item-price small { font-size: 11.5px; }

.aior-cart-item-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  background: transparent;
  border: 0;
  border-radius: var(--r-sm);
  color: var(--fg-muted);
  cursor: pointer;
  transition: background 160ms, color 160ms;
}
.aior-cart-item-remove:hover {
  background: color-mix(in srgb, #dc2626 10%, transparent);
  color: #dc2626;
}

/* Empty cart — within items list (kept for safety) */
.aior-cart-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 56px 24px;
  color: var(--fg-muted);
}
.aior-cart-empty p { margin: 0; font-size: 15px; color: var(--fg-soft); }

/* === Empty cart — full-page layout (production parity) === */
.aior-cart-empty-page {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px 24px;
}
.aior-cart-empty-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 32rem;
  width: 100%;
}
.aior-cart-empty-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 120px; height: 120px;
  margin-bottom: 24px;
  color: var(--accent, #1da1f2);
}
.aior-cart-empty-icon svg {
  color: inherit;
  display: block;
}
.aior-cart-empty-title {
  margin: 0 0 28px;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fg, #f7f8fa);
}
.aior-cart-empty-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  padding: 0 24px;
  border-radius: var(--r-sm, 6px);
  background: transparent;
  color: var(--fg, #f7f8fa);
  border: 1px solid var(--line, rgba(255,255,255,0.14));
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: background 160ms, border-color 160ms;
}
.aior-cart-empty-cta:hover {
  background: var(--bg-soft, rgba(255,255,255,0.06));
  border-color: var(--line-strong, rgba(255,255,255,0.24));
  color: var(--fg, #f7f8fa);
}

/* Domain period select */
.aior-domain-period-select { display: inline-block; margin-top: 4px; }

/* Express checkout */
.aior-cart-express { padding: 14px 18px; }

/* Cart tabs */
.aior-cart-tabs { margin-top: 4px; }

/* Order summary */
.aior-cart-summary { padding: 22px; }
.aior-cart-summary-loader {
  position: absolute;
  top: 12px; right: 12px;
  font-size: 18px;
  color: var(--accent);
}
.aior-cart-summary-title {
  margin: 0 0 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fg);
}
.aior-cart-summary-list {
  margin: 0 0 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 14px;
}
.aior-cart-summary-list > div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.aior-cart-summary-list dt { margin: 0; color: var(--fg-soft); }
.aior-cart-summary-list dd { margin: 0; font-weight: 600; color: var(--fg); }

.aior-cart-recurring {
  margin: 0 0 16px;
  padding: 12px 14px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  font-size: 13px;
}
.aior-cart-recurring-label { margin: 0 0 6px; font-size: 11.5px; font-weight: 600; color: var(--fg-muted); letter-spacing: 0.06em; text-transform: uppercase; }
.aior-cart-recurring-list { display: flex; flex-direction: column; gap: 4px; }

.aior-cart-total-due {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 18px 14px;
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--line));
  border-radius: var(--r-md);
}
.aior-cart-total-amount {
  font-size: 30px;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--accent-deep);
  line-height: 1;
}
.aior-cart-total-label {
  margin-top: 6px;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-muted);
}

/* Disabled state for buttons */
.aior-btn.disabled,
.aior-btn-block.disabled,
.btn.disabled {
  opacity: 0.5;
  pointer-events: none;
  cursor: not-allowed;
}

.aior-text-success { color: #16a34a; }

/* ============================================================
   FOOTER-MOUNTED UTILITIES (footer.tpl)
   Tüm bu elementler default GİZLİ olmalı; JS açtığında görünür.
   ============================================================ */

/* Cookie consent — sayfa altında küçük banner */
.cookie-consent {
  position: fixed;
  bottom: 16px;
  left: 16px;
  right: 16px;
  z-index: 1100;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px 18px;
  box-shadow: 0 16px 40px -16px rgba(0, 0, 0, 0.45);
  display: none;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 768px) {
  .cookie-consent { left: auto; right: 16px; bottom: 16px; max-width: 480px; }
}
.cookie-consent[data-open="true"] { display: flex; }
.cookie-consent-text {
  flex: 1;
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg-soft);
  min-width: 200px;
}
.cookie-consent-link {
  font-size: 12.5px;
  color: var(--accent-deep);
  text-decoration: none;
  font-weight: 500;
}
.cookie-consent-link:hover { color: var(--accent); text-decoration: underline; }
.cookie-consent-btn {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  border-radius: var(--r-sm);
  background: var(--accent);
  color: #fff;
  border: 0;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background 160ms;
}
.cookie-consent-btn:hover { background: var(--accent-deep); }

/* Fullpage loader overlay — JS controls aria-hidden */
.aior-overlay {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(2px);
}
.aior-overlay[aria-hidden="false"] { display: flex; }
.aior-overlay-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 28px 32px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--fg);
  box-shadow: 0 20px 60px -20px rgba(0, 0, 0, 0.6);
}
.aior-spinner { font-size: 28px; color: var(--accent); }
.aior-overlay-msg { font-size: 13.5px; color: var(--fg-soft); }

/* Custom modal (replaces Bootstrap #modalAjax for scripts.min.js) */
.aior-modal {
  position: fixed;
  inset: 0;
  z-index: 1300;
  display: none;
}
.aior-modal[aria-hidden="false"] { display: block; }
.aior-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(2px);
}
.aior-modal-dialog {
  position: relative;
  margin: 60px auto;
  max-width: 560px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: 0 32px 80px -24px rgba(0, 0, 0, 0.55);
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 120px);
  overflow: hidden;
}
.aior-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 22px;
  border-bottom: 1px solid var(--line);
}
.aior-modal-title {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: var(--fg);
}
.aior-modal-close {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 0;
  border-radius: var(--r-sm);
  color: var(--fg-muted);
  cursor: pointer;
  font-size: 18px;
  transition: background 160ms, color 160ms;
}
.aior-modal-close:hover { background: var(--bg); color: var(--fg); }
.aior-modal-body {
  padding: 18px 22px;
  overflow: auto;
  color: var(--fg);
  font-size: 14px;
  line-height: 1.55;
}
.aior-modal-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 22px;
  border-top: 1px solid var(--line);
  background: var(--bg);
}
.aior-modal-loader {
  display: none;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: var(--fg-muted);
}
.aior-modal[data-loading="true"] .aior-modal-loader { display: inline-flex; }
.aior-modal-actions {
  display: flex;
  gap: 8px;
  margin-left: auto;
}

/* Generate-password modal & other hidden helpers */
[data-modal][aria-hidden="true"],
.aior-modal[aria-hidden="true"] { display: none; }

/* Scroll-to-top FAB */
.scroll-top-fab {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 50;
  width: 44px;
  height: 44px;
  display: none;
  align-items: center;
  justify-content: center;
  background: var(--accent);
  color: #fff;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 8px 20px -6px rgba(0, 0, 0, 0.45);
  transition: background 160ms, transform 160ms;
}
.scroll-top-fab.is-visible { display: inline-flex; }
.scroll-top-fab:hover { background: var(--accent-deep); transform: translateY(-2px); }

/* WhatsApp FAB */
.wa-fab {
  position: fixed;
  bottom: 24px;
  left: 24px;
  z-index: 50;
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #25D366;
  color: #fff;
  border-radius: 50%;
  text-decoration: none;
  box-shadow: 0 12px 28px -10px rgba(37, 211, 102, 0.6);
  transition: transform 160ms, box-shadow 160ms;
}
.wa-fab:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 36px -10px rgba(37, 211, 102, 0.7);
  color: #fff;
}

/* ============================================================
   5. STORE / PRODUCTS PAGE (aior_cart products.tpl)
   ============================================================ */

.aior-store-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .aior-store-grid { grid-template-columns: 240px 1fr; align-items: flex-start; }
}
.aior-store-sidebar { min-width: 0; }
@media (min-width: 1024px) { .aior-store-sidebar { position: sticky; top: 100px; } }
.aior-store-content { min-width: 0; }

/* Product card grid */
.aior-product-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .aior-product-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1280px) { .aior-product-grid { grid-template-columns: repeat(3, 1fr); } }

.aior-product-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: transform 200ms, box-shadow 200ms, border-color 200ms;
}
.aior-product-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--accent) 30%, var(--line));
  box-shadow: 0 12px 32px -16px color-mix(in srgb, var(--accent) 30%, transparent);
}
.aior-product-card-head {
  padding: 18px 22px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.aior-product-card-title {
  margin: 0;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--fg);
  line-height: 1.3;
}

.aior-product-card-body {
  flex: 1;
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.aior-product-card-desc {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--fg-soft);
}
.aior-product-card-features {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 13.5px;
  color: var(--fg);
}
.aior-product-card-features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  line-height: 1.4;
}
.aior-product-card-features li i {
  color: #16a34a;
  margin-top: 3px;
  flex-shrink: 0;
  font-size: 11px;
}
.aior-product-card-features strong { font-weight: 600; color: var(--fg); }

.aior-product-card-foot {
  padding: 18px 22px;
  border-top: 1px solid var(--line);
  background: var(--bg);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.aior-product-card-price {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: center;
}
.aior-product-card-pricelabel {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.aior-product-card-priceval {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--accent-deep);
  line-height: 1;
}
.aior-product-card-pricecycle {
  font-size: 12.5px;
  color: var(--fg-muted);
  margin-top: 2px;
}
.aior-product-card-setup {
  margin-top: 4px;
  font-size: 11.5px;
}

/* Store sidebar (categories list) */
.aior-store-sidebar .panel-sidebar,
.aior-store-sidebar .card-sidebar {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}

/* ============================================================
   6. PAGE HERO + BREADCRUMB (Astro PageHero.astro paritesi)
   ============================================================ */

.page-hero {
  position: relative;
  background: #0d1117;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -3;
  pointer-events: none;
}
.page-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
  opacity: 0.35;
  filter: grayscale(0.4) contrast(1.05);
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background: rgba(13, 17, 23, 0.78);
  pointer-events: none;
}
.page-hero-particles {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  display: block;
}
.page-hero-content {
  position: relative;
  padding: 18px 16px 28px;
}
@media (min-width: 768px) {
  .page-hero-content { padding: 22px 24px 36px; }
}
.page-hero-text {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 8px;
}
.page-hero-eyebrow {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
}
.page-hero-title {
  font-size: clamp(24px, 3.4vw, 34px);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0;
  line-height: 1.15;
}
.page-hero-sub {
  font-size: 14.5px;
  color: rgba(255, 255, 255, 0.72);
  margin: 0 auto;
  max-width: 70ch;
  line-height: 1.5;
}

/* Breadcrumb — Astro global.css paritesi (line 4834-4879) */
.breadcrumb { font-size: 13px; }
.breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.breadcrumb-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}
.breadcrumb-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: rgba(255, 255, 255, 0.6);
  text-decoration: none;
  transition: color 0.12s;
  white-space: nowrap;
}
.breadcrumb-link:hover { color: var(--accent); }
.breadcrumb-home { font-weight: 500; }
.breadcrumb-brand {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  letter-spacing: -0.01em;
}
.breadcrumb-sep {
  color: rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
}
.breadcrumb-current {
  display: inline-flex;
  align-items: center;
  color: #fff;
  font-weight: 500;
  max-width: 60ch;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Hero now sits OUTSIDE .aior-main (rendered between header & main). The
   .aior-main top padding (28px) provides the natural gap between hero and
   page content — no special override needed. */

/* ==========================================================
   AIOR Domain Register / Checker
   --------------------------------------------------------------
   WHMCS scripts.min.js drives availability via class hooks
   (.domain-{available,unavailable,invalid,tld-unavailable},
   .btn-add-to-cart, .price, [data-domain]). DO NOT rename
   those — only AIOR aior-domain-* classes are styled here.
   3-ton palette: page (--bg) → card (--bg-soft) → input (--bg-sunken).
   Accent = Twitter blue (--accent). Status uses accent (no green).
   ========================================================== */

.aior-domain-page {
  --aior-dom-page:  var(--bg);
  --aior-dom-card:  var(--bg-soft);
  --aior-dom-input: var(--bg-sunken);
  --aior-dom-line:  var(--line);
  --aior-dom-fg:    var(--fg);
  --aior-dom-mute:  var(--fg-muted);
  --aior-dom-acc:   var(--accent);
  --aior-dom-acc-d: var(--accent-deep);
  --aior-dom-acc-s: var(--accent-soft);
  --aior-dom-radius: var(--r-lg);
  background: var(--aior-dom-page);
  color: var(--aior-dom-fg);
  padding-block: 36px 64px;
}

.aior-domain-shell {
  max-width: 1080px;
  margin-inline: auto;
  padding-inline: 20px;
}

/* ----- HERO ----- */
.aior-domain-hero {
  background: var(--aior-dom-card);
  border: 1px solid var(--aior-dom-line);
  border-radius: var(--aior-dom-radius);
  padding: 40px 24px 30px;
  text-align: center;
}
.aior-domain-hero-inner {
  max-width: 820px;
  margin-inline: auto;
}
.aior-domain-hero-title {
  font-family: var(--font-sans);
  font-size: clamp(22px, 3.5vw, 30px);
  font-weight: 700;
  letter-spacing: -.01em;
  margin: 0 0 6px;
  color: var(--aior-dom-fg);
}
.aior-domain-hero-sub {
  font-size: 14px;
  color: var(--aior-dom-mute);
  margin: 0 0 22px;
}

/* Search bar — single pill */
.aior-domain-search { margin: 0; }
.aior-domain-search .domain-checker-bg {
  background: transparent;
  padding: 0;
  border: 0;
}
.aior-domain-form { margin: 0; }
.aior-domain-search-bar.input-group {
  display: flex;
  align-items: stretch;
  gap: 0;
  width: 100%;
  background: var(--aior-dom-input);
  border: 1px solid var(--aior-dom-line);
  border-radius: var(--r-pill);
  padding: 6px;
  box-shadow: var(--sh-sm) inset;
}
.aior-domain-input,
input.aior-domain-input,
textarea.aior-domain-input {
  flex: 1 1 auto;
  appearance: none;
  background: transparent;
  border: 0;
  outline: 0;
  box-shadow: none !important;
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--aior-dom-fg);
  padding: 12px 18px;
  min-height: 40px;
  border-radius: var(--r-pill);
}
.aior-domain-input::placeholder,
textarea.aior-domain-input::placeholder { color: var(--fg-faint); }
.aior-domain-input:focus { background: rgba(0,0,0,0); }
textarea.aior-domain-input { min-height: 96px; resize: vertical; padding-top: 14px; }

.aior-domain-search-bar .input-group-btn,
.aior-domain-search-bar .input-group-append {
  display: flex;
  align-items: stretch;
}
.aior-domain-search-btn,
.btn.aior-domain-search-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--aior-dom-acc);
  color: #fff;
  border: 0;
  border-radius: var(--r-pill);
  padding: 0 22px;
  min-height: 44px;
  font-family: var(--font-sans);
  font-size: 14.5px;
  font-weight: 700;
  letter-spacing: .01em;
  cursor: pointer;
  transition: background var(--dur) var(--ease), transform var(--dur-fast) var(--ease);
}
.aior-domain-search-btn:hover,
.btn.aior-domain-search-btn:hover { background: var(--aior-dom-acc-d); color: #fff; }
.aior-domain-search-btn:active { transform: translateY(1px); }
.aior-domain-search-btn svg { stroke: currentColor; }

/* Search-actions group: Ara + Transfer side by side inside the pill */
.aior-domain-search-actions {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
}
.aior-domain-transfer-btn,
.btn.aior-domain-transfer-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  color: var(--aior-dom-acc-d);
  border: 1px solid var(--aior-dom-acc);
  border-radius: var(--r-pill);
  padding: 0 18px;
  min-height: 44px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .01em;
  cursor: pointer;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), transform var(--dur-fast) var(--ease);
}
.aior-domain-transfer-btn:hover,
.btn.aior-domain-transfer-btn:hover {
  background: var(--aior-dom-acc);
  color: #fff;
  transform: translateY(-1px);
}
.aior-domain-transfer-btn:active { transform: translateY(0); }
.aior-domain-transfer-btn svg { stroke: currentColor; transition: transform 160ms ease; }
.aior-domain-transfer-btn:hover svg { transform: translateX(2px); }
[data-theme="dark"] .aior-domain-transfer-btn,
:root[data-theme="dark"] .aior-domain-transfer-btn {
  color: color-mix(in srgb, var(--aior-dom-acc) 92%, #fff);
  border-color: color-mix(in srgb, var(--aior-dom-acc) 60%, transparent);
}

/* Mobile — stack actions below input */
@media (max-width: 560px) {
  .aior-domain-search-actions {
    width: 100%;
    margin-top: 6px;
  }
  .aior-domain-search-actions .aior-domain-search-btn,
  .aior-domain-search-actions .aior-domain-transfer-btn {
    flex: 1;
    justify-content: center;
    min-height: 40px;
  }
}

/* Toggle row (Gelişmiş / Çoklu) */
.aior-domain-toggle-row {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 16px;
  flex-wrap: wrap;
}
.aior-domain-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--aior-dom-input);
  border: 1px solid var(--aior-dom-line);
  border-radius: var(--r-md);
  padding: 8px 14px;
  font-size: 13px;
  color: var(--aior-dom-fg);
  text-decoration: none;
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.aior-domain-toggle:hover { border-color: var(--aior-dom-acc); color: var(--aior-dom-acc-d); text-decoration: none; }
.aior-domain-toggle.is-active { border-color: var(--aior-dom-acc); color: var(--aior-dom-acc-d); background: var(--aior-dom-acc-s); }
.aior-domain-toggle svg { stroke: currentColor; }

.aior-domain-captcha { margin-top: 16px; }

/* ----- TLD RAIL ----- */
.aior-domain-tld-rail-section {
  position: relative;
  margin-top: 24px;
  display: grid;
  grid-template-columns: 36px 1fr 36px;
  align-items: center;
  gap: 8px;
}
.aior-domain-tld-rail-arrow {
  appearance: none;
  background: var(--aior-dom-card);
  border: 1px solid var(--aior-dom-line);
  border-radius: 999px;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--aior-dom-mute);
  cursor: pointer;
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.aior-domain-tld-rail-arrow:hover { border-color: var(--aior-dom-acc); color: var(--aior-dom-acc); background: var(--aior-dom-acc-s); }

.aior-domain-tld-rail {
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.aior-domain-tld-rail::-webkit-scrollbar { display: none; }
.aior-domain-tld-rail-track {
  display: flex;
  gap: 12px;
  padding: 4px 2px 8px;
}
.aior-domain-tld-card {
  flex: 0 0 150px;
  scroll-snap-align: start;
  background: var(--aior-dom-card);
  border: 1px solid var(--aior-dom-line);
  border-radius: var(--aior-dom-radius);
  padding: 14px 14px 12px;
  text-align: center;
  position: relative;
  transition: border-color var(--dur) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur) var(--ease);
}
.aior-domain-tld-card:hover { border-color: var(--aior-dom-acc); transform: translateY(-2px); box-shadow: var(--sh-md); }
.aior-domain-tld-card .spotlight-tld {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.aior-domain-tld-card-tag {
  position: absolute;
  top: 8px;
  right: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  background: var(--aior-dom-acc-s);
  color: var(--aior-dom-acc-d);
  padding: 2px 6px;
  border-radius: var(--r-sm);
}
.aior-domain-tld-card-name {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 18px;
  color: var(--aior-dom-fg);
  letter-spacing: -.01em;
}
.aior-domain-tld-card-price {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 13px;
  color: var(--aior-dom-fg);
  min-height: 36px;
  align-items: center;
}
.aior-domain-tld-card-price .price { font-weight: 700; color: var(--aior-dom-acc-d); }
.aior-domain-tld-card-btn,
.aior-domain-tld-card .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 600;
  border-radius: var(--r-sm);
  padding: 6px 12px;
  border: 1px solid transparent;
  background: var(--aior-dom-acc);
  color: #fff;
  cursor: pointer;
}
.aior-domain-tld-card-btn:hover { background: var(--aior-dom-acc-d); color: #fff; }
.aior-domain-tld-card-btn.unavailable,
.aior-domain-tld-card-btn.invalid {
  background: var(--aior-dom-input);
  color: var(--aior-dom-mute);
  border-color: var(--aior-dom-line);
  cursor: not-allowed;
}
.aior-domain-tld-card .domain-lookup-spotlight-loader {
  color: var(--aior-dom-mute);
  animation: aiorDomSpin 1s linear infinite;
  display: inline-flex;
}
@keyframes aiorDomSpin { to { transform: rotate(360deg); } }

/* ----- RESULTS ----- */
.aior-domain-results {
  margin-top: 28px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.aior-domain-section-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--aior-dom-mute);
  margin: 0 0 12px;
  padding: 0;
  border: 0;
  background: transparent;
}
.aior-domain-section-title svg { color: var(--aior-dom-acc); }
.aior-domain-section-title--ghost { padding: 0 4px; }

.aior-domain-result-card {
  background: var(--aior-dom-card);
  border: 1px solid var(--aior-dom-line);
  border-radius: var(--aior-dom-radius);
  padding: 0;
  overflow: hidden;
}

.aior-domain-loader {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 22px;
  margin: 0;
  color: var(--aior-dom-mute);
  font-size: 14px;
}
.aior-domain-loader svg { animation: aiorDomSpin 1s linear infinite; color: var(--aior-dom-acc); }
.aior-domain-loader-msg {
  padding: 22px;
  text-align: center;
  color: var(--aior-dom-mute);
  font-size: 13.5px;
}

/* Result row: status | detail | action */
.aior-domain-result-row {
  display: grid;
  grid-template-columns: 132px 1fr auto;
  align-items: stretch;
  gap: 0;
  min-height: 96px;
}
@media (max-width: 720px) {
  .aior-domain-result-row {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }
}

.aior-domain-status {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--aior-dom-input);
  border-right: 1px solid var(--aior-dom-line);
  padding: 16px 12px;
}
@media (max-width: 720px) {
  .aior-domain-status { border-right: 0; border-bottom: 1px solid var(--aior-dom-line); }
}

.aior-domain-status-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .02em;
  color: var(--aior-dom-fg);
  text-align: center;
}
.aior-domain-status-badge svg {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  padding: 7px;
  background: var(--aior-dom-card);
}
.aior-domain-status-badge--available { color: var(--aior-dom-acc-d); }
.aior-domain-status-badge--available svg {
  background: var(--aior-dom-acc);
  color: #fff;
  border: 0;
}
.aior-domain-status-badge--unavailable { color: var(--crit); }
.aior-domain-status-badge--unavailable svg {
  background: rgba(239, 68, 68, .12);
  color: var(--crit);
}
.aior-domain-status-badge--invalid { color: var(--warn); }
.aior-domain-status-badge--invalid svg {
  background: rgba(245, 158, 11, .14);
  color: var(--warn);
}

.aior-domain-detail {
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
}
.aior-domain-detail-name {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--aior-dom-fg);
  letter-spacing: -.01em;
}
.aior-domain-detail-name:empty::before {
  content: attr(data-placeholder);
  color: var(--fg-faint);
}
.aior-domain-detail-msg {
  margin: 0;
  font-size: 13.5px;
  color: var(--aior-dom-mute);
  line-height: 1.5;
}
.aior-domain-detail-msg.domain-checker-unavailable { color: var(--crit); }
.aior-domain-detail-msg.domain-checker-invalid { color: var(--warn); }
.aior-domain-detail-msg.domain-checker-available { color: var(--aior-dom-fg); }

.aior-domain-action {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  background: var(--aior-dom-card);
  border-left: 1px solid var(--aior-dom-line);
  margin: 0;
}
@media (max-width: 720px) {
  .aior-domain-action {
    border-left: 0;
    border-top: 1px solid var(--aior-dom-line);
    justify-content: space-between;
  }
}
.aior-domain-price {
  display: flex;
  flex-direction: column;
  gap: 0;
  font-family: var(--font-sans);
  text-align: right;
  line-height: 1.1;
}
.aior-domain-price-amount {
  font-size: 17px;
  font-weight: 700;
  color: var(--aior-dom-fg);
}
.aior-domain-price-period {
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--crit);
  font-style: italic;
}

.aior-btn.aior-btn--primary,
.aior-btn--primary.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--aior-dom-acc);
  color: #fff;
  border: 0;
  border-radius: var(--r-md);
  padding: 10px 18px;
  min-height: 40px;
  font-family: var(--font-sans);
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: .01em;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--dur) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur) var(--ease);
}
.aior-btn.aior-btn--primary:hover,
.aior-btn--primary.btn:hover { background: var(--aior-dom-acc-d); color: #fff; box-shadow: 0 4px 12px var(--accent-ring); }
.aior-btn.aior-btn--primary:active { transform: translateY(1px); }
.aior-btn--sm { font-size: 12.5px; padding: 6px 12px; min-height: 32px; border-radius: var(--r-sm); }
.aior-btn--cart svg { stroke: currentColor; }

/* Primary cart button — center icon + label cleanly.
   Only the *visible* state-span is flex; the others stay hidden. */
.aior-domain-action .btn-add-to-cart {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  text-align: center !important;
  white-space: nowrap;
  min-width: 130px;
}
/* Default: only .to-add is visible (initial state) */
.aior-domain-action .btn-add-to-cart .to-add,
.aior-domain-action .btn-add-to-cart.loading .loading,
.aior-domain-action .btn-add-to-cart.checkout .added,
.aior-domain-action .btn-add-to-cart.added .added,
.aior-domain-action .btn-add-to-cart.unavailable .unavailable {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  white-space: nowrap !important;
}
/* Inner SVG + label always inline */
.aior-domain-action .btn-add-to-cart .to-add > *,
.aior-domain-action .btn-add-to-cart .loading > *,
.aior-domain-action .btn-add-to-cart .added > *,
.aior-domain-action .btn-add-to-cart .unavailable > * {
  display: inline-flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  vertical-align: middle !important;
}
/* Hide non-active states */
.aior-domain-action .btn-add-to-cart .loading,
.aior-domain-action .btn-add-to-cart .added,
.aior-domain-action .btn-add-to-cart .unavailable { display: none !important; }
.aior-domain-action .btn-add-to-cart.loading .to-add,
.aior-domain-action .btn-add-to-cart.checkout .to-add,
.aior-domain-action .btn-add-to-cart.added .to-add,
.aior-domain-action .btn-add-to-cart.unavailable .to-add { display: none !important; }
.aior-domain-action .btn-add-to-cart svg { flex-shrink: 0 !important; }

/* WHMCS button state visibility */
.aior-domain-action .btn-add-to-cart .loading,
.aior-domain-action .btn-add-to-cart .added,
.aior-domain-action .btn-add-to-cart .unavailable { display: none; }
.aior-domain-action .btn-add-to-cart.loading .to-add,
.aior-domain-action .btn-add-to-cart.added .to-add,
.aior-domain-action .btn-add-to-cart.unavailable .to-add { display: none; }
.aior-domain-action .btn-add-to-cart.loading .loading { display: inline-flex; align-items: center; gap: 6px; }
.aior-domain-action .btn-add-to-cart.added .added { display: inline-flex; align-items: center; gap: 6px; }
.aior-domain-action .btn-add-to-cart.unavailable .unavailable { display: inline; }

/* ----- SUGGESTIONS ----- */
.aior-domain-suggestions {
  background: var(--aior-dom-card);
  border: 1px solid var(--aior-dom-line);
  border-radius: var(--aior-dom-radius);
  overflow: hidden;
}
.aior-domain-suggestions .panel-heading,
.aior-domain-suggestions .card-header {
  background: transparent;
  border: 0;
  padding: 16px 22px 8px;
}
.aior-domain-suggestions-list {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0;
  list-style: none;
  border: 0;
}
.aior-domain-suggestion-row {
  display: grid;
  grid-template-columns: 24px 1fr auto auto;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  border-top: 1px solid var(--aior-dom-line);
  background: var(--aior-dom-card);
  transition: background var(--dur) var(--ease);
}
.aior-domain-suggestion-row:hover { background: var(--aior-dom-input); }
.aior-domain-suggestion-row:first-of-type { border-top: 0; }
@media (max-width: 720px) {
  .aior-domain-suggestion-row {
    grid-template-columns: 24px 1fr;
    grid-template-rows: auto auto;
    padding: 14px;
  }
  .aior-domain-suggestion-actions { grid-column: 1 / -1; justify-content: flex-end; }
}
.aior-domain-suggestion-check {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--aior-dom-acc);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.aior-domain-suggestion-name {
  font-family: var(--font-mono);
  font-size: 14.5px;
  font-weight: 600;
  color: var(--aior-dom-fg);
  letter-spacing: -.01em;
}
.aior-domain-suggestion-name .extension { color: var(--aior-dom-acc-d); }
.aior-domain-suggestion-tag {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--aior-dom-acc-d);
  background: var(--aior-dom-acc-s);
  padding: 2px 6px;
  border-radius: var(--r-sm);
}
.aior-domain-suggestion-actions {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.aior-domain-suggestion-price {
  font-family: var(--font-sans);
  font-size: 13.5px;
  font-weight: 700;
  color: var(--aior-dom-fg);
  white-space: nowrap;
}
.aior-domain-suggestions-list .btn-add-to-cart .loading,
.aior-domain-suggestions-list .btn-add-to-cart .added,
.aior-domain-suggestions-list .btn-add-to-cart .unavailable { display: none; }
.aior-domain-suggestions-list .btn-add-to-cart.loading .to-add,
.aior-domain-suggestions-list .btn-add-to-cart.added .to-add,
.aior-domain-suggestions-list .btn-add-to-cart.unavailable .to-add { display: none; }
.aior-domain-suggestions-list .btn-add-to-cart.loading .loading { display: inline-flex; align-items: center; gap: 4px; }
.aior-domain-suggestions-list .btn-add-to-cart.added .added { display: inline-flex; align-items: center; gap: 4px; }
.aior-domain-suggestions-list .btn-add-to-cart.unavailable .unavailable { display: inline; }

.aior-domain-more { padding: 16px 22px; border-top: 1px solid var(--aior-dom-line); }
.aior-btn-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--aior-dom-acc-d);
  text-decoration: none;
}
.aior-btn-link:hover { color: var(--aior-dom-acc); text-decoration: underline; }
.aior-domain-suggestions-warning { padding: 12px 22px 18px; font-size: 12px; color: var(--fg-faint); }

.aior-text-muted { color: var(--aior-dom-mute); font-size: 13px; }

/* ----- MARKETING ----- */
.aior-domain-marketing { margin-top: 56px; }
.aior-domain-marketing-grid {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 36px;
  align-items: start;
}
@media (max-width: 760px) {
  .aior-domain-marketing-grid { grid-template-columns: 1fr; }
  .aior-domain-marketing-art { order: -1; max-width: 200px; margin-inline: auto; }
}
.aior-domain-marketing-art svg {
  width: 100%;
  height: auto;
  display: block;
}
.aior-domain-marketing-text { color: var(--aior-dom-fg); font-size: 14.5px; line-height: 1.7; }
.aior-domain-marketing-text p { margin: 0 0 12px; color: var(--aior-dom-fg); }
.aior-domain-marketing-text strong { color: var(--aior-dom-fg); font-weight: 700; }
.aior-domain-marketing-title {
  font-size: clamp(20px, 2.6vw, 26px);
  font-weight: 700;
  letter-spacing: -.01em;
  margin: 0 0 14px;
  color: var(--aior-dom-fg);
}
.aior-domain-marketing-highlight {
  margin-top: 18px;
  padding: 12px 16px;
  background: var(--aior-dom-acc-s);
  color: var(--aior-dom-acc-d);
  border-radius: var(--r-md);
  font-weight: 600;
}

/* ----- FEATURES ----- */
.aior-domain-features { margin-top: 56px; }
.aior-domain-features-title,
.aior-domain-faq-title {
  font-size: clamp(20px, 2.6vw, 26px);
  font-weight: 700;
  letter-spacing: -.01em;
  margin: 0 0 6px;
  color: var(--aior-dom-fg);
}
.aior-domain-features-sub {
  margin: 0 0 24px;
  color: var(--aior-dom-mute);
  font-size: 14px;
}
.aior-domain-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}
.aior-domain-feature-card {
  background: var(--aior-dom-card);
  border: 1px solid var(--aior-dom-line);
  border-radius: var(--aior-dom-radius);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color var(--dur) var(--ease), transform var(--dur-fast) var(--ease);
}
.aior-domain-feature-card:hover { border-color: var(--aior-dom-acc); transform: translateY(-2px); }
.aior-domain-feature-check {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--aior-dom-acc);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 4px;
}
.aior-domain-feature-title {
  font-size: 14.5px;
  font-weight: 700;
  margin: 0;
  color: var(--aior-dom-fg);
}
.aior-domain-feature-desc {
  margin: 0;
  font-size: 13px;
  color: var(--aior-dom-mute);
  line-height: 1.5;
}

/* ----- FAQ ----- */
.aior-domain-faq { margin-top: 56px; }
.aior-domain-faq-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.aior-domain-faq-item {
  background: var(--aior-dom-card);
  border: 1px solid var(--aior-dom-line);
  border-radius: var(--aior-dom-radius);
  overflow: hidden;
}
.aior-domain-faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 18px;
  font-size: 14.5px;
  font-weight: 600;
  color: var(--aior-dom-fg);
  cursor: pointer;
  list-style: none;
}
.aior-domain-faq-q::-webkit-details-marker { display: none; }
.aior-domain-faq-q:hover { color: var(--aior-dom-acc-d); }
.aior-domain-faq-chev {
  flex-shrink: 0;
  color: var(--aior-dom-mute);
  transition: transform var(--dur) var(--ease), color var(--dur) var(--ease);
}
.aior-domain-faq-item[open] .aior-domain-faq-chev { transform: rotate(180deg); color: var(--aior-dom-acc); }
.aior-domain-faq-a {
  padding: 0 18px 16px;
  color: var(--aior-dom-fg);
  font-size: 13.5px;
  line-height: 1.65;
}
.aior-domain-faq-a p { margin: 0; }

/* ----- WHMCS visibility helpers (preserve) ----- */
.aior-domain-results .w-hidden { display: none !important; }
.aior-domain-results.w-hidden { display: none !important; }
.aior-domain-tld-rail .w-hidden { display: none !important; }
/* WHMCS toggles section titles via JS — only show what fits the state */
.primary-domain-header { display: none; }

/* ==========================================================
   AIOR Client Area — clientareahome.tpl + alt sayfalar
   --------------------------------------------------------------
   3-ton: page (--bg) → card (--bg-soft) → input (--bg-sunken)
   Accent: Twitter mavisi (--accent). Yeşil yok (status-mavi).
   Gece/gündüz: aior-theme.css token'ları otomatik swap eder.
   TR/EN: data-tr/data-en attr'leri aior-theme.js handle eder.
   ========================================================== */

/* ---- STACK (vertical spacing helpers) ---- */
.aior-stack-lg { display: flex; flex-direction: column; gap: 28px; }
.aior-stack-lg > * { margin: 0; }

/* ---- STATS GRID (clientareahome dashboard kartları) ---- */
.aior-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}
.aior-stat-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 18px 20px;
  color: var(--fg);
  text-decoration: none !important;
  transition: border-color var(--dur) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur) var(--ease);
}
.aior-stat-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: var(--sh-md);
  color: var(--fg);
  text-decoration: none !important;
}
.aior-stat-icon {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  margin-bottom: 4px;
}
.aior-stat-value {
  font-family: var(--font-sans);
  font-size: 28px;
  font-weight: 800;
  line-height: 1.1;
  color: var(--fg);
  margin: 0;
}
.aior-stat-label {
  font-size: 13px;
  color: var(--fg-muted);
  margin: 0;
  font-weight: 500;
  letter-spacing: .01em;
}

/* ---- SIDE LIST (sol nav, son işlemler vb.) ---- */
.aior-side-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.aior-side-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px;
  border-radius: var(--r-md);
  color: var(--fg);
  text-decoration: none !important;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.aior-side-link:hover {
  background: var(--accent-tint);
  color: var(--accent-deep);
}
.aior-side-link.is-active {
  background: var(--accent);
  color: #fff;
}
.aior-side-link-count {
  font-size: 12px;
  font-weight: 700;
  background: var(--bg-sunken);
  color: var(--fg-muted);
  padding: 2px 8px;
  border-radius: 999px;
  min-width: 22px;
  text-align: center;
}
.aior-side-link.is-active .aior-side-link-count {
  background: rgba(255,255,255,.2);
  color: #fff;
}

/* ---- FIELD (form field wrapper, label + input) ---- */
.aior-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}
.aior-field .aior-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--fg-soft);
}

/* ---- ALERT (extension: error variant) ---- */
.aior-alert-error {
  background: rgba(239, 68, 68, .08);
  border: 1px solid rgba(239, 68, 68, .25);
  color: var(--crit);
}

/* ---- BADGE (extension: brand variant) ---- */
.aior-badge-brand {
  background: var(--accent-soft);
  color: var(--accent-deep);
}

/* ---- BTN soft variant (clientarea actions) ---- */
.aior-btn-soft,
.aior-btn.aior-btn-soft {
  background: var(--bg-sunken);
  color: var(--fg);
  border: 1px solid var(--line);
}
.aior-btn-soft:hover,
.aior-btn.aior-btn-soft:hover {
  background: var(--accent-tint);
  border-color: var(--accent);
  color: var(--accent-deep);
}
.aior-btn-sm { padding: 6px 12px; font-size: 12.5px; min-height: 32px; }

/* ---- INPUT WRAP (icon-prefixed input) ---- */
.aior-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.aior-input-icon {
  position: absolute;
  left: 12px;
  color: var(--fg-muted);
  pointer-events: none;
}
.aior-input-wrap .aior-input { padding-left: 38px; }

/* ---- CARD title (extension) ---- */
.aior-card-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--fg);
  margin: 0;
  letter-spacing: -.005em;
}

/* ---- WHMCS native sınıflarını aior-card ile sarılı şekilde nötralize et ---- */
.aior-card .alert,
.aior-card .panel,
.aior-card .well {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
}


/* ----- AIOR step message — error/success states (görünür) ----- */
.aior-reg-step-msg[data-kind="error"] {
  background: rgba(239, 68, 68, 0.10);
  border: 1px solid rgba(239, 68, 68, 0.30);
  padding: 10px 14px;
  border-radius: 8px;
  font-weight: 600;
  margin-top: 14px;
}
.aior-reg-step-msg[data-kind="success"] {
  background: rgba(16, 185, 129, 0.10);
  border: 1px solid rgba(16, 185, 129, 0.30);
  padding: 10px 14px;
  border-radius: 8px;
  font-weight: 600;
  margin-top: 14px;
}
.aior-reg-step-msg[data-kind="warn"] {
  background: rgba(245, 158, 11, 0.10);
  border: 1px solid rgba(245, 158, 11, 0.30);
  padding: 10px 14px;
  border-radius: 8px;
  font-weight: 600;
  margin-top: 14px;
}


/* ----- Login alt linkler — buton tarzı (her step ortak) ----- */
.aior-login-actions {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 18px 0 24px;
}
.aior-login-actions .aior-login-action-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 10px 18px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--fg);
  text-decoration: none !important;
  transition: border-color .22s ease, background .22s ease, color .22s ease, transform .12s ease;
  min-height: 40px;
}
.aior-login-actions .aior-login-action-link:hover {
  background: var(--accent-tint);
  border-color: var(--accent);
  color: var(--accent-deep);
  transform: translateY(-1px);
}
.aior-login-action-sep { display: none; }

/* ----- Footer tagline top (h3 → p) — ufak, bold, accent mavi ----- */
.footer-tagline-top {
  font-size: 14px;
  font-weight: 700;
  color: var(--accent-deep);
  letter-spacing: -0.005em;
  margin: 0 0 24px;
  max-width: 760px;
  line-height: 1.55;
}

/* === KILL WHMCS standard_cart's yellow `.domain-checker-container` gradient
   AND all `.spotlight-tld*` rail-style rules; we render our own list. === */
.aior-domain-page .domain-checker-container,
#order-standard_cart .domain-checker-container {
  background: transparent !important;
  background-color: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
}
.aior-domain-page .spotlight-tlds,
.aior-domain-page .spotlight-tlds-container,
.aior-domain-page .spotlight-tld-container,
.aior-domain-page [class*="spotlight-tld-container-"] {
  all: unset; display: block;
}

/* ============================================================
/* ============================================================
   AIOR Domain Search Results — full visual rewrite (light + dark)
   Matches the user-supplied design:
   - Big status panel left (Müsait green / Müsait değil grey)
   - Big domain name + optional message in centre
   - Available  → price + green "Sepete At"
   - Taken      → grey Whois (active) + WWW (disabled-look) pair
   - "Daha Fazla Sonuç Göster" warm-orange centered pill
   ============================================================ */

/* === Variables (theme-aware shortcuts) === */
.aior-domain-page {
  --r-card: 8px;
  --r-pill: 4px;
  --color-ok:        #28a745;
  --color-ok-deep:   #218838;
  --color-bad:       #94a3b8;
  --color-bad-deep:  #64748b;
  --color-row:       #f4f5f7;
  --color-row-hover: #ebedf1;
  --color-fg:        #2c2c2c;
  --color-fg-mute:   #888;
  --color-price-period: #e74c3c;
  --color-loadmore:  #d99553;
  --color-loadmore-deep: #b07239;
}
[data-theme="dark"] .aior-domain-page,
:root[data-theme="dark"] .aior-domain-page {
  --color-row:       #181b22;
  --color-row-hover: #1f242d;
  --color-fg:        #e2e8f0;
  --color-fg-mute:   #94a3b8;
  --color-bad:       #475569;
  --color-bad-deep:  #334155;
  --color-loadmore:  #c47a3a;
  --color-loadmore-deep: #9a5b2a;
}

/* Hard dark overrides — variables alone aren't winning against
   WHMCS standard_cart all.css (which sets .spotlight-tld bg/border).
   We force the dark theme on every result surface. */
:root[data-theme="dark"] .aior-domain-spotlight-rows,
[data-theme="dark"] .aior-domain-spotlight-rows {
  background: transparent !important;
}
:root[data-theme="dark"] .aior-domain-spotlight-row,
[data-theme="dark"] .aior-domain-spotlight-row {
  background: #181b22 !important;
  color: #e2e8f0 !important;
  border-color: #1f242d !important;
}
:root[data-theme="dark"] .aior-domain-spotlight-row:hover,
[data-theme="dark"] .aior-domain-spotlight-row:hover {
  background: #1f242d !important;
}
:root[data-theme="dark"] .aior-domain-spotlight-name,
[data-theme="dark"] .aior-domain-spotlight-name {
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .aior-domain-spotlight-row.is-taken .aior-domain-spotlight-name,
[data-theme="dark"] .aior-domain-spotlight-row.is-taken .aior-domain-spotlight-name {
  color: #94a3b8 !important;
}
:root[data-theme="dark"] .aior-domain-other-rows,
[data-theme="dark"] .aior-domain-other-rows {
  background: #181b22 !important;
}
:root[data-theme="dark"] .aior-domain-other-row,
[data-theme="dark"] .aior-domain-other-row {
  background: transparent !important;
  border-top-color: rgba(255,255,255,.06) !important;
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .aior-domain-other-row .aior-domain-spotlight-name,
[data-theme="dark"] .aior-domain-other-row .aior-domain-spotlight-name {
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .aior-domain-other-tlds .aior-domain-section-title,
[data-theme="dark"] .aior-domain-other-tlds .aior-domain-section-title {
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .aior-spotlight-price-amount,
[data-theme="dark"] .aior-spotlight-price-amount {
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .aior-spotlight-status-taken,
[data-theme="dark"] .aior-spotlight-status-taken,
:root[data-theme="dark"] .aior-spotlight-status-pending,
[data-theme="dark"] .aior-spotlight-status-pending {
  color: #94a3b8 !important;
}
/* Status block (left) — tone down whites in dark */
:root[data-theme="dark"] .aior-domain-spotlight-row.is-taken .aior-domain-spotlight-status-block,
[data-theme="dark"] .aior-domain-spotlight-row.is-taken .aior-domain-spotlight-status-block {
  background: #475569 !important;
}
:root[data-theme="dark"] .aior-domain-spotlight-row.is-pending .aior-domain-spotlight-status-block,
[data-theme="dark"] .aior-domain-spotlight-row.is-pending .aior-domain-spotlight-status-block {
  background: #334155 !important;
}
/* Whois button pair — keep contrast in dark */
:root[data-theme="dark"] .aior-btn--whois,
[data-theme="dark"] .aior-btn--whois {
  background: #334155 !important;
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .aior-btn--www,
[data-theme="dark"] .aior-btn--www {
  background: #475569 !important;
  color: #e2e8f0 !important;
  opacity: 0.85 !important;
}
:root[data-theme="dark"] .aior-btn--www:hover,
[data-theme="dark"] .aior-btn--www:hover {
  background: #1d9bf0 !important;
  color: #ffffff !important;
  opacity: 1 !important;
}
/* Round status icon for "DİĞER UZANTILAR" — dark variants */
:root[data-theme="dark"] .aior-domain-other-row .aior-domain-spotlight-name::before,
[data-theme="dark"] .aior-domain-other-row .aior-domain-spotlight-name::before {
  background-color: #475569;
}
:root[data-theme="dark"] .aior-domain-other-row.is-available .aior-domain-spotlight-name::before,
[data-theme="dark"] .aior-domain-other-row.is-available .aior-domain-spotlight-name::before {
  background-color: #16a34a;
}
/* Hero (form area) on cart page — dark override */
:root[data-theme="dark"] .aior-domain-hero,
[data-theme="dark"] .aior-domain-hero {
  background: transparent !important;
}
:root[data-theme="dark"] .aior-domain-hero-title,
[data-theme="dark"] .aior-domain-hero-title {
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .aior-domain-hero-sub,
[data-theme="dark"] .aior-domain-hero-sub {
  color: #94a3b8 !important;
}
:root[data-theme="dark"] .aior-domain-search-bar.input-group,
[data-theme="dark"] .aior-domain-search-bar.input-group {
  background: #0f1115 !important;
  border-color: #1f2937 !important;
}
:root[data-theme="dark"] .aior-domain-input,
[data-theme="dark"] .aior-domain-input,
:root[data-theme="dark"] #inputDomain,
[data-theme="dark"] #inputDomain {
  background: transparent !important;
  color: #e2e8f0 !important;
  border-color: transparent !important;
}
:root[data-theme="dark"] .aior-domain-input::placeholder,
[data-theme="dark"] .aior-domain-input::placeholder {
  color: #94a3b8 !important;
}
:root[data-theme="dark"] .aior-domain-toggle,
[data-theme="dark"] .aior-domain-toggle {
  background: #1f2937 !important;
  color: #e2e8f0 !important;
  border-color: #374151 !important;
}
:root[data-theme="dark"] .aior-domain-toggle:hover,
[data-theme="dark"] .aior-domain-toggle:hover {
  border-color: #1d9bf0 !important;
}
:root[data-theme="dark"] .aior-domain-toggle.is-active,
[data-theme="dark"] .aior-domain-toggle.is-active {
  background: rgba(29, 155, 240, 0.15) !important;
  border-color: #1d9bf0 !important;
  color: #1d9bf0 !important;
}
:root[data-theme="dark"] .aior-domain-result-card.domain-checker-result-headline,
[data-theme="dark"] .aior-domain-result-card.domain-checker-result-headline {
  background: #181b22 !important;
}
:root[data-theme="dark"] #primaryLookupResult,
[data-theme="dark"] #primaryLookupResult {
  background: #181b22 !important;
  color: #e2e8f0 !important;
  border-color: #1f242d !important;
}
:root[data-theme="dark"] .aior-domain-detail-name,
[data-theme="dark"] .aior-domain-detail-name {
  color: #e2e8f0 !important;
}
/* Domain register hero/page background in dark */
:root[data-theme="dark"] .aior-domain-page,
[data-theme="dark"] .aior-domain-page {
  background: transparent !important;
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] #DomainSearchResults,
[data-theme="dark"] #DomainSearchResults {
  background: transparent !important;
  color: #e2e8f0 !important;
}
/* SORGU SONUÇLARI heading */
:root[data-theme="dark"] .aior-domain-section-title,
[data-theme="dark"] .aior-domain-section-title {
  color: #e2e8f0 !important;
}
/* Marketing area on register page */
:root[data-theme="dark"] .aior-domain-marketing,
[data-theme="dark"] .aior-domain-marketing,
:root[data-theme="dark"] .aior-domain-features,
[data-theme="dark"] .aior-domain-features {
  background: #0f1115 !important;
  color: #e2e8f0 !important;
}
:root[data-theme="dark"] .aior-domain-marketing-title,
[data-theme="dark"] .aior-domain-marketing-title,
:root[data-theme="dark"] .aior-domain-features-title,
[data-theme="dark"] .aior-domain-features-title {
  color: #e2e8f0 !important;
}

/* === Spotlight rows (SORGU SONUÇLARI section) === */
.aior-domain-spotlight-rows {
  display: block !important;
  margin-top: 14px;
  border-radius: 0;
  border: 0;
  background: transparent;
  overflow: visible;
}
.aior-domain-spotlight-row {
  display: grid !important;
  grid-template-columns: 110px 1fr auto !important;
  align-items: stretch;
  gap: 0;
  margin-bottom: 8px;
  border-radius: var(--r-card);
  overflow: hidden;
  background: var(--color-row);
  width: auto !important;
  float: none !important;
  min-height: 56px;
  padding: 0 !important;
  border: 0 !important;
  transition: background 140ms ease;
}
.aior-domain-spotlight-status-block {
  padding: 6px 8px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  gap: 3px !important;
}
.aior-domain-spotlight-status-block svg {
  width: 18px !important;
  height: 18px !important;
}
.aior-domain-spotlight-name {
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 14px !important;
  font-size: 15px !important;
  line-height: 1.3 !important;
}
.aior-domain-spotlight-name .aior-spotlight-ext {
  font-size: 15px !important;
}
.aior-domain-spotlight-row:hover { background: var(--color-row-hover); }
.aior-domain-spotlight-row:first-child { border-top: 0; }

/* Left status block */
.aior-domain-spotlight-row::before {
  content: '';
  display: none;
}
.aior-domain-spotlight-status-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  padding: 8px;
}
.aior-domain-spotlight-status-block svg {
  width: 26px; height: 26px;
}
.aior-domain-spotlight-row.is-available .aior-domain-spotlight-status-block { background: var(--color-ok); }
.aior-domain-spotlight-row.is-taken     .aior-domain-spotlight-status-block { background: var(--color-bad); }
.aior-domain-spotlight-row.is-pending   .aior-domain-spotlight-status-block { background: var(--color-bad); opacity: .7; }

/* Domain name centre */
.aior-domain-spotlight-name {
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  padding: 12px 18px;
  min-width: 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--color-fg);
  word-break: break-all;
  line-height: 1.25;
}
.aior-domain-spotlight-name .aior-spotlight-ext {
  color: inherit;
  font-weight: 700;
}
.aior-domain-spotlight-row.is-taken .aior-domain-spotlight-name {
  color: var(--color-fg-mute);
}
.aior-domain-spotlight-row .aior-spotlight-bonus {
  font-size: 12px;
  font-weight: 500;
  color: var(--color-price-period);
  font-style: italic;
  margin-top: 2px;
}

/* Right actions */
.aior-spotlight-actions,
.aior-domain-spotlight-row .aior-spotlight-actions {
  display: flex !important;
  align-items: center;
  justify-content: flex-end;
  gap: 0;
  padding: 0 14px;
  flex-wrap: nowrap;
  white-space: nowrap;
}

/* Loader during check */
.aior-spotlight-loader {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 18px;
  font-size: 12px;
  color: var(--color-fg-mute);
  font-style: italic;
}
.aior-spotlight-loader svg { animation: aior-spotlight-spin 1s linear infinite; }
@keyframes aior-spotlight-spin {
  from { transform: rotate(0); } to { transform: rotate(360deg); }
}

/* Available state — price + green Sepete At */
.aior-spotlight-price-amount {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-fg);
  font-variant-numeric: tabular-nums;
  margin-right: 14px;
  line-height: 1.1;
}
.aior-spotlight-price-amount::after {
  content: attr(data-period-tr);
  display: block;
  font-size: 11px;
  font-style: italic;
  color: var(--color-price-period);
  font-weight: 500;
  margin-top: 1px;
}
[data-lang="en"] .aior-spotlight-price-amount::after { content: attr(data-period-en); }

.aior-domain-spotlight-row .btn-add-to-cart {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 18px;
  border-radius: var(--r-pill);
  font-size: 14px;
  font-weight: 600;
  background: var(--color-ok);
  color: #fff;
  border: 0;
  cursor: pointer;
  transition: background 140ms ease;
  min-height: 40px;
}
.aior-domain-spotlight-row .btn-add-to-cart:hover { background: var(--color-ok-deep); }

/* Taken state — Whois + WWW pair (greyed) */
.aior-btn--whois,
.aior-btn--www {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 22px;
  font-size: 13px;
  font-weight: 600;
  border: 0;
  cursor: pointer;
  text-decoration: none;
  min-width: 80px;
  min-height: 40px;
  transition: background 140ms ease;
}
.aior-btn--whois {
  background: var(--color-bad-deep);
  color: #fff;
  border-radius: var(--r-pill) 0 0 var(--r-pill);
}
.aior-btn--whois:hover { background: #475569; }
.aior-btn--www {
  background: var(--color-bad);
  color: #fff;
  border-radius: 0 var(--r-pill) var(--r-pill) 0;
  pointer-events: none;
  opacity: .55;
  cursor: not-allowed;
}

.aior-spotlight-status-taken {
  display: inline-block;
  padding: 0 18px;
  font-size: 13px;
  color: var(--color-fg-mute);
  font-style: italic;
}
.aior-spotlight-status-pending {
  display: inline-block;
  padding: 0 18px;
  font-size: 12.5px;
  color: var(--color-fg-mute);
  font-style: italic;
}

/* === DİĞER UZANTILAR — compact list rows === */
.aior-domain-other-tlds {
  margin-top: 18px;
}
.aior-domain-other-tlds .aior-domain-section-title {
  display: block;
  margin: 0 0 10px;
  padding: 0;
  border: 0;
  background: transparent;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--color-fg);
}
.aior-domain-other-rows {
  background: var(--color-row);
  border-radius: var(--r-card);
  padding: 0;
  overflow: hidden;
}
.aior-domain-other-row {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  align-items: center;
  gap: 12px;
  padding: 14px 18px !important;
  border-top: 1px solid rgba(0,0,0,.05);
  background: transparent !important;
  width: auto !important;
  float: none !important;
  min-height: 56px;
  margin: 0 !important;
  border-radius: 0 !important;
}
[data-theme="dark"] .aior-domain-other-row {
  border-top-color: rgba(255,255,255,.05);
}
.aior-domain-other-row:first-child { border-top: 0; }
.aior-domain-other-row .aior-domain-spotlight-name {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px;
  font-size: 15px !important;
  font-weight: 500;
  padding: 0 !important;
  color: var(--color-fg);
}
.aior-domain-other-row .aior-domain-spotlight-name::before {
  content: '';
  display: inline-block;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--color-bad);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round'><line x1='18' y1='6' x2='6' y2='18'/><line x1='6' y1='6' x2='18' y2='18'/></svg>");
  background-size: 14px;
  background-repeat: no-repeat;
  background-position: center;
}
.aior-domain-other-row.is-available .aior-domain-spotlight-name::before {
  background-color: var(--color-ok);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
}
.aior-domain-other-row.is-pending .aior-domain-spotlight-name::before {
  background: var(--color-bad);
  opacity: .55;
}
.aior-domain-other-row .aior-spotlight-actions {
  padding: 0 !important;
}
.aior-domain-other-row .btn-add-to-cart,
.aior-domain-other-row .aior-btn--whois,
.aior-domain-other-row .aior-btn--www {
  min-height: 32px;
  padding: 6px 16px;
  font-size: 12.5px;
  min-width: 70px;
}
.aior-domain-other-row .aior-spotlight-price-amount {
  margin-right: 12px;
}
.aior-domain-other-row .aior-spotlight-status-taken {
  padding: 0 12px;
}

/* === Loadmore + check-all action bar === */
.aior-domain-loadmore-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 24px 0 8px !important;
  margin-top: 8px;
  border-top: 0 !important;
  background: transparent !important;
  width: 100%;
}
.aior-domain-loadmore {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 14px 32px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  background: #d99553 !important;
  color: #ffffff !important;
  border: 0 !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  transition: background 140ms ease;
  min-height: 46px;
  text-decoration: none;
  outline: none;
  box-shadow: 0 2px 6px rgba(217, 149, 83, .25);
}
.aior-domain-loadmore:hover { background: #b07239 !important; }
.aior-domain-loadmore:active { transform: translateY(1px); }
.aior-domain-loadmore svg { display: none !important; }
[data-theme="dark"] .aior-domain-loadmore { background: #c47a3a !important; }
[data-theme="dark"] .aior-domain-loadmore:hover { background: #9a5b2a !important; }

.aior-domain-loadmore-count {
  font-size: 12px;
  color: rgba(255,255,255,.85);
  font-weight: 500;
  margin-left: 4px;
}
.aior-domain-checkall {
  display: inline-flex !important;
  align-items: center;
  font-size: 12.5px !important;
  background: transparent !important;
  color: #888 !important;
  border: 1px dashed #94a3b8 !important;
  padding: 8px 16px !important;
  border-radius: 6px !important;
  cursor: pointer;
}
.aior-domain-checkall:hover {
  color: #2c2c2c !important;
  border-color: #888 !important;
}
[data-theme="dark"] .aior-domain-checkall { color: #94a3b8 !important; }
[data-theme="dark"] .aior-domain-checkall:hover { color: #e2e8f0 !important; }

.aior-domain-other-row[hidden] { display: none !important; }

/* Mobile */
@media (max-width: 720px) {
  .aior-domain-spotlight-row {
    grid-template-columns: 90px 1fr !important;
  }
  .aior-domain-spotlight-row .aior-spotlight-actions {
    grid-column: 1 / -1;
    justify-content: stretch;
    padding: 10px 14px;
    border-top: 1px solid rgba(0,0,0,.05);
  }
  [data-theme="dark"] .aior-domain-spotlight-row .aior-spotlight-actions {
    border-top-color: rgba(255,255,255,.05);
  }
  .aior-domain-spotlight-name { padding: 12px 14px; font-size: 16px; }
  .aior-domain-other-row {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 12px 14px !important;
  }
  .aior-domain-other-row .aior-spotlight-actions {
    justify-content: space-between;
  }
}


/* ============================================================
   AIOR WHOIS Modal — re-added (was lost in spotlight rewrite)
   Theme-aware, opaque backdrop, scrollable body.
   ============================================================ */
/* Centered, strong-blur modal */
.aior-whois-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;        /* center vertically */
  justify-content: center;    /* center horizontally */
  padding: 24px 16px;
  overflow-y: auto;
  animation: aior-whois-fade 180ms ease;
}
.aior-whois-modal[hidden] { display: none !important; }
.aior-whois-modal.is-open { display: flex !important; }
@keyframes aior-whois-fade {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.aior-whois-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(8, 12, 22, 0.78);
  backdrop-filter: blur(10px) saturate(1.2);
  -webkit-backdrop-filter: blur(10px) saturate(1.2);
}
.aior-whois-modal-card {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 760px;
  background: var(--aior-dom-card, #fff);
  border-radius: 14px;
  box-shadow: 0 30px 80px -10px rgba(0,0,0,.5);
  overflow: hidden;
  border: 1px solid var(--aior-dom-line, #e5e7eb);
}
.aior-whois-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 20px;
  background: linear-gradient(135deg, var(--aior-dom-acc, #1da1f2), var(--aior-dom-acc-d, #0d7fc2));
  color: #fff;
}
.aior-whois-modal-title {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.aior-whois-modal-close {
  background: rgba(255,255,255,0.18);
  border: 0;
  color: #fff;
  width: 34px; height: 34px;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 140ms ease;
}
.aior-whois-modal-close:hover { background: rgba(255,255,255,0.30); }
.aior-whois-modal-body {
  padding: 18px 20px 22px;
  max-height: 70vh;
  overflow-y: auto;
  background: var(--aior-dom-card, #fff);
}
.aior-whois-loader {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--aior-dom-mute, #64748b);
  font-style: italic;
}
.aior-whois-loader[style*="display: none"],
.aior-whois-loader[style*="display:none"] { display: none !important; }
.aior-whois-loader svg { animation: aior-spotlight-spin 1s linear infinite; }
.aior-whois-modal-text {
  margin: 0;
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--aior-dom-fg, #0f172a);
  white-space: pre-wrap;
  word-break: break-word;
  background: var(--aior-dom-input, #f8fafc);
  padding: 14px 16px;
  border-radius: 8px;
  border: 1px solid var(--aior-dom-line, #e5e7eb);
}
.aior-whois-modal-text[style*="display: none"],
.aior-whois-modal-text[style*="display:none"] { display: none !important; }
.aior-whois-modal-error {
  background: color-mix(in srgb, #ef4444 14%, transparent);
  color: #b91c1c;
  border: 1px solid color-mix(in srgb, #ef4444 35%, transparent);
  padding: 12px 14px;
  border-radius: 8px;
  margin: 0;
  font-size: 13px;
}
.aior-whois-modal-error[style*="display: none"],
.aior-whois-modal-error[style*="display:none"] { display: none !important; }
[data-theme="dark"] .aior-whois-modal-text {
  background: #0f1115;
  color: #e2e8f0;
  border-color: #1f2937;
}
body.aior-modal-open { overflow: hidden; }

/* WWW button — clickable, opens in new tab. Was previously disabled-look,
   now keeps muted styling but is fully interactive. */
.aior-btn--www {
  pointer-events: auto !important;
  opacity: 1 !important;
  cursor: pointer !important;
}
.aior-btn--www:hover {
  background: var(--color-bad-deep, #64748b) !important;
}

@media (max-width: 640px) {
  .aior-whois-modal { padding: 16px 8px; }
  .aior-whois-modal-card { max-width: 100%; }
  .aior-whois-modal-text { font-size: 11.5px; }
}
