/* ==========================================================
   ICTDialer Design System — Divi Integration
   Loaded after divi-style; use !important only where Divi
   specificity requires it.
   ========================================================== */

/* ---- Design tokens ---- */
:root {
  --brand-h: 268;
  --brand-c: 0.165;
  --brand:     oklch(0.55 var(--brand-c) var(--brand-h));
  --brand-600: oklch(0.50 var(--brand-c) var(--brand-h));
  --brand-700: oklch(0.44 var(--brand-c) var(--brand-h));
  --brand-300: oklch(0.74 calc(var(--brand-c) * 0.7) var(--brand-h));
  --brand-100: oklch(0.94 0.03 var(--brand-h));
  --brand-tint:oklch(0.97 0.018 var(--brand-h));
  --accent:    oklch(0.78 0.14 200);
  --accent-ink:oklch(0.62 0.13 200);
  --bg:        #ffffff;
  --bg-alt:    oklch(0.985 0.004 270);
  --surface:   #ffffff;
  --surface-2: oklch(0.975 0.005 270);
  --ink:       oklch(0.22 0.02 270);
  --ink-2:     oklch(0.30 0.02 270);
  --muted:     oklch(0.52 0.015 270);
  --faint:     oklch(0.66 0.012 270);
  --border:    oklch(0.91 0.006 270);
  --border-2:  oklch(0.86 0.008 270);
  --night:     oklch(0.21 0.028 274);
  --night-2:   oklch(0.26 0.032 274);
  --font-display: "Bricolage Grotesque", "Space Grotesk", system-ui, sans-serif;
  --font-body:    "Plus Jakarta Sans", system-ui, sans-serif;
  --r-sm:  8px;
  --r:     14px;
  --r-lg:  20px;
  --r-xl:  28px;
  --r-pill:999px;
  --shadow-sm: 0 1px 2px rgba(16,18,40,.06), 0 1px 1px rgba(16,18,40,.04);
  --shadow:    0 8px 24px -8px rgba(20,22,55,.16), 0 2px 6px -2px rgba(20,22,55,.08);
  --shadow-lg: 0 30px 60px -18px rgba(24,20,70,.30), 0 8px 20px -8px rgba(24,20,70,.14);
  --shadow-brand: 0 18px 40px -14px oklch(0.55 var(--brand-c) var(--brand-h) / .45);
  --maxw: 1200px;
  --gut:  clamp(20px, 5vw, 56px);
}

/* ---- Global typography ---- */
body {
  font-family: var(--font-body) !important;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4, h5,
.et_pb_blurb_title,
.et_pb_slide_title,
.et_pb_portfolio_title {
  font-family: var(--font-display) !important;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.et_pb_text, .et_pb_text_inner, .et_pb_module {
  font-family: var(--font-body) !important;
}

/* ================================================================
   DIVI HEADER OVERRIDES
   ================================================================ */
#main-header,
#main-header.et-fixed-header {
  background: linear-gradient(90deg, var(--brand-700), var(--brand-600) 55%, var(--brand)) !important;
  border-bottom: 1px solid rgba(255,255,255,.12) !important;
  transition: box-shadow .3s, background .3s !important;
}
#main-header.scrolled,
#main-header.et-fixed-header.scrolled {
  box-shadow: 0 10px 30px -12px rgba(20,18,60,.45) !important;
}
/* Logo text */
#main-header .logo_container span,
#main-header .logo_helper,
.logo_container .et_pb_image_wrap {
  font-family: var(--font-display) !important;
}
/* Primary nav links */
#top-menu > li > a,
#top-menu a,
#et-top-navigation nav > ul > li > a {
  color: rgba(255,255,255,.86) !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  font-size: 15px !important;
}
#top-menu > li > a:hover,
#top-menu a:hover,
#et-top-navigation nav > ul > li > a:hover {
  color: #fff !important;
  background: rgba(255,255,255,.14) !important;
  border-radius: 9px;
}
/* Dropdown menus */
#top-menu .sub-menu {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--shadow-lg) !important;
}
#top-menu .sub-menu li a {
  color: var(--ink) !important;
  font-size: 14.5px !important;
}
#top-menu .sub-menu li a:hover {
  color: var(--brand) !important;
  background: var(--surface-2) !important;
}
/* Header CTA button */
#main-header .et_pb_button,
#main-header .et_pb_button_module_wrapper a {
  background: #fff !important;
  color: var(--brand-700) !important;
  border-color: transparent !important;
  border-radius: var(--r-pill) !important;
  font-weight: 600 !important;
  box-shadow: 0 8px 22px -10px rgba(0,0,0,.5) !important;
}
#main-header .et_pb_button:hover,
#main-header .et_pb_button_module_wrapper a:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 26px -10px rgba(0,0,0,.55) !important;
}
/* Mobile menu burger */
#et_mobile_nav_menu .mobile_menu_bar::before {
  color: #fff !important;
}
.et_mobile_menu,
.et_mobile_menu li a {
  background: var(--brand-700) !important;
  color: rgba(255,255,255,.9) !important;
}

/* ================================================================
   DIVI FOOTER OVERRIDES
   ================================================================ */
#main-footer {
  background: var(--night) !important;
  color: rgba(255,255,255,.78) !important;
}
#footer-widgets {
  background: var(--night) !important;
  padding-top: 54px;
  padding-bottom: 40px;
}
#footer-widgets .footer-widget h4,
#footer-widgets .footer-widget .widget-title {
  color: rgba(255,255,255,.5) !important;
  font-family: var(--font-display) !important;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: .04em;
  margin-bottom: 16px;
}
#footer-widgets .footer-widget li,
#footer-widgets .footer-widget li a {
  color: rgba(255,255,255,.78) !important;
  font-size: 14.5px;
  line-height: 2;
}
#footer-widgets .footer-widget li a:hover {
  color: var(--accent) !important;
}
#footer-info {
  background: var(--night) !important;
  border-top: 1px solid rgba(255,255,255,.12) !important;
  color: rgba(255,255,255,.55) !important;
  font-size: 13.5px;
}
#footer-info a { color: rgba(255,255,255,.7) !important; }
#footer-info a:hover { color: var(--accent) !important; }
/* Social icons in footer */
#footer-widgets .et_pb_social_media_follow li a,
#footer-widgets .et_follow_link {
  background: rgba(255,255,255,.08) !important;
  border-radius: 10px;
}
#footer-widgets .et_pb_social_media_follow li a:hover {
  background: var(--brand) !important;
}

/* ================================================================
   GLOBAL DIVI BUTTON OVERRIDES
   ================================================================ */
.et_pb_button,
.et_pb_promo_button,
.woocommerce a.button,
.woocommerce button.button {
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  border-radius: var(--r-pill) !important;
  transition: transform .15s ease, box-shadow .2s ease !important;
}
.et_pb_button:hover {
  transform: translateY(-2px) !important;
}

/* ================================================================
   LAYOUT UTILITIES (used in page templates)
   ================================================================ */
.ict-wrap {
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: var(--gut);
}
.ict-section      { padding-block: clamp(64px, 9vw, 130px); }
.ict-section-sm   { padding-block: clamp(48px, 6vw, 84px); }
.ict-center       { text-align: center; }
.ict-center .ict-eyebrow { justify-content: center; }

.ict-eyebrow {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--brand);
  display: inline-flex;
  align-items: center;
  gap: 9px;
}
.ict-eyebrow::before {
  content: "";
  width: 22px;
  height: 2px;
  background: var(--brand);
  border-radius: 2px;
}
.ict-h-xl { font-size: clamp(40px, 6.2vw, 76px); line-height: 1.05; letter-spacing: -0.02em; font-family: var(--font-display); font-weight: 700; margin: 0; }
.ict-h-lg { font-size: clamp(32px, 4.4vw, 54px); line-height: 1.05; letter-spacing: -0.02em; font-family: var(--font-display); font-weight: 700; margin: 0; }
.ict-lead { font-size: clamp(18px, 1.4vw, 21px); color: var(--muted); line-height: 1.62; }

/* ================================================================
   BUTTONS (used in page templates)
   ================================================================ */
.ict-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 15.5px;
  padding: 13px 22px;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s;
  white-space: nowrap;
  text-decoration: none;
}
.ict-btn:active { transform: translateY(1px); }
.ict-btn-primary { background: var(--brand); color: #fff !important; box-shadow: var(--shadow-brand); }
.ict-btn-primary:hover { background: var(--brand-600); transform: translateY(-2px); color: #fff !important; }
.ict-btn-ghost { background: transparent; color: var(--ink) !important; border-color: var(--border-2); }
.ict-btn-ghost:hover { border-color: var(--brand); color: var(--brand) !important; }
.ict-btn-light { background: rgba(255,255,255,.12); color:#fff !important; border-color: rgba(255,255,255,.22); backdrop-filter: blur(6px); }
.ict-btn-light:hover { background: rgba(255,255,255,.2); }
.ict-btn-white { background:#fff; color: var(--night) !important; }
.ict-btn-white:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); color: var(--night) !important; }
.ict-btn-lg { padding: 16px 28px; font-size: 16.5px; }
.ict-btn .ict-arrow { transition: transform .2s ease; }
.ict-btn:hover .ict-arrow { transform: translateX(3px); }

/* ================================================================
   HERO
   ================================================================ */
.ict-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(170deg, var(--brand-tint) 0%, var(--bg-alt) 42%, var(--bg) 100%);
}
.ict-hero-bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.ict-hero-bg .ict-blob { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .5; }
.ict-hero-bg .ict-b1 { width: 560px; height: 560px; top: -180px; right: -120px; background: var(--brand-300); }
.ict-hero-bg .ict-b2 { width: 420px; height: 420px; top: 120px; left: -160px; background: var(--accent); opacity: .28; }
.ict-hero-grid { position:absolute; inset:0; background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px); background-size: 56px 56px; mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 30%, transparent 75%); opacity: .5; }
.ict-hero-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(28px, 4vw, 64px);
  align-items: center;
  padding-block: clamp(56px, 8vw, 96px) clamp(40px, 6vw, 80px);
}
.ict-hero-inner h1 { margin-top: 18px; }
.ict-hero-inner h1 .ict-grad {
  background: linear-gradient(100deg, var(--brand), var(--accent-ink));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.ict-hero-inner .ict-lead { margin-top: 22px; max-width: 52ch; }
.ict-hero-cta { display: flex; gap: 13px; margin-top: 30px; flex-wrap: wrap; }
.ict-hero-trust { display: flex; align-items: center; gap: 16px; margin-top: 26px; color: var(--faint); font-size: 14px; font-weight: 500; flex-wrap: wrap; }
.ict-hero-trust .ict-stars { color: #f6a609; letter-spacing: 2px; }
.ict-hero-trust .ict-divider { width: 1px; height: 22px; background: var(--border-2); }

/* ================================================================
   PRODUCT MOCK
   ================================================================ */
.ict-mock {
  position: relative;
  border-radius: var(--r-lg);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.ict-mock-bar { display: flex; align-items: center; gap: 8px; padding: 12px 15px; border-bottom: 1px solid var(--border); background: var(--surface-2); }
.ict-mock-bar .ict-dot { width: 11px; height: 11px; border-radius: 50%; }
.ict-mock-bar .ict-dot:nth-child(1){ background:#ff5f57;}
.ict-mock-bar .ict-dot:nth-child(2){ background:#febc2e;}
.ict-mock-bar .ict-dot:nth-child(3){ background:#28c840;}
.ict-mock-bar .ict-url { margin-left: 10px; font-size: 12px; color: var(--faint); background: var(--bg); border:1px solid var(--border); padding: 4px 12px; border-radius: var(--r-pill); }
.ict-mock-body { display: grid; grid-template-columns: 64px 1fr; min-height: 360px; }
.ict-mock-side { background: var(--night); padding: 16px 0; display: flex; flex-direction: column; align-items: center; gap: 7px; }
.ict-mock-side .ict-mlogo { width: 32px; height: 32px; border-radius: 9px; background: linear-gradient(135deg, var(--brand), var(--brand-700)); margin-bottom: 8px; }
.ict-mock-side .ict-mi { width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; color: rgba(255,255,255,.55); }
.ict-mock-side .ict-mi.active { background: rgba(255,255,255,.14); color: #fff; }
.ict-mock-side .ict-mi svg { width: 18px; height: 18px; }
.ict-mock-main { padding: 18px; background: var(--bg-alt); display: flex; flex-direction: column; gap: 14px; }
.ict-mock-head { display: flex; align-items: center; justify-content: space-between; }
.ict-mock-head .ict-t { font-family: var(--font-display); font-weight: 700; font-size: 16px; }
.ict-live-badge { display:inline-flex; align-items:center; gap:6px; font-size: 11px; font-weight: 700; color: oklch(0.55 0.16 150); background: oklch(0.94 0.06 150); padding: 4px 10px; border-radius: var(--r-pill); }
.ict-live-badge .ict-pulse { width: 7px; height: 7px; border-radius: 50%; background: oklch(0.6 0.18 150); box-shadow: 0 0 0 0 oklch(0.6 0.18 150 / .6); animation: ict-pulse 1.8s infinite; }
@keyframes ict-pulse { 70%{ box-shadow: 0 0 0 7px transparent;} 100%{ box-shadow: 0 0 0 0 transparent;} }
.ict-kpi-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.ict-kpi { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 11px 12px; }
.ict-kpi .ict-lbl { font-size: 10.5px; color: var(--faint); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; }
.ict-kpi .ict-val { font-family: var(--font-display); font-weight: 700; font-size: 21px; margin-top: 3px; }
.ict-mock-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 13px; }
.ict-bars { display: flex; align-items: flex-end; gap: 7px; height: 78px; margin-top: 10px; }
.ict-bars span { flex: 1; border-radius: 4px 4px 0 0; background: linear-gradient(var(--brand-300), var(--brand)); opacity: .9; }
.ict-agent-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-top: 1px solid var(--border); font-size: 12.5px; }
.ict-agent-row:first-of-type { border-top: 0; }
.ict-ava { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg,var(--brand-300),var(--brand)); flex:none; display:grid; place-items:center; color:#fff; font-size:10px; font-weight:700; font-family: var(--font-display);}
.ict-agent-row .ict-nm { font-weight: 600; }
.ict-agent-row .ict-st { margin-left: auto; font-size: 11px; font-weight: 700; padding: 2px 9px; border-radius: var(--r-pill); }
.ict-st-on   { background: oklch(0.94 0.06 150); color: oklch(0.5 0.14 150); }
.ict-st-idle { background: var(--surface-2); color: var(--faint); }
.ict-st-call { background: var(--brand-tint); color: var(--brand); }
.ict-mock-float { position: absolute; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); box-shadow: var(--shadow-lg); padding: 12px 14px; display: flex; gap: 11px; align-items: center; }
.ict-mock-float .ict-fic { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; color: #fff; flex:none; }
.ict-mf-1 { bottom: 26px; left: -28px; }
.ict-mf-2 { top: 70px; right: -22px; }
.ict-mock-float .ict-ti { font-size: 11px; color: var(--faint); font-weight: 600; }
.ict-mock-float .ict-tv { font-family: var(--font-display); font-weight: 700; font-size: 16px; }
.ict-hero-visual { position: relative; }

/* ================================================================
   LOGOS STRIP
   ================================================================ */
.ict-logos { display: flex; align-items: center; justify-content: space-between; gap: 30px; flex-wrap: wrap; opacity: .72; }
.ict-logos .ict-lg { font-family: var(--font-display); font-weight: 700; font-size: clamp(16px,2vw,21px); color: var(--muted); letter-spacing: -.02em; display:flex; align-items:center; gap:8px; }
.ict-logos .ict-lg svg { width: 22px; height: 22px; opacity:.85; }

/* ================================================================
   CHANNEL CARDS (Voice / SMS / Fax)
   ================================================================ */
.ict-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.ict-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.ict-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.ict-channel {
  position: relative;
  padding: 30px;
  border-radius: var(--r-lg);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: 0 1px 2px rgba(16,18,40,.06);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s;
}
.ict-channel:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: var(--brand-300); }
.ict-channel .ict-ic { width: 54px; height: 54px; border-radius: 15px; display: grid; place-items: center; color: #fff; margin-bottom: 18px; box-shadow: var(--shadow-brand); }
.ict-channel .ict-ic svg { width: 26px; height: 26px; }
.ict-channel h3 { font-size: 22px; font-family: var(--font-display); font-weight: 700; margin: 0; }
.ict-channel p { color: var(--muted); margin-top: 9px; font-size: 15.5px; margin-bottom: 0; }
.ict-channel .ict-feat { margin-top: 16px; display: flex; flex-direction: column; gap: 8px; padding: 0; list-style: none; }
.ict-channel .ict-feat li { display: flex; align-items: center; gap: 9px; font-size: 14.5px; color: var(--ink-2); font-weight: 500; }
.ict-channel .ict-feat svg { width: 16px; height: 16px; color: var(--brand); flex:none; }
.ict-channel .ict-glow { position: absolute; top: -40px; right: -40px; width: 130px; height: 130px; border-radius: 50%; filter: blur(40px); opacity: .25; }

/* ================================================================
   FEATURE CARDS
   ================================================================ */
.ict-feat-card { padding: 26px; border-radius: var(--r); background: var(--surface); border: 1px solid var(--border); transition: transform .2s, box-shadow .2s, border-color .2s; }
.ict-feat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--brand-300); }
.ict-feat-card .ict-ic { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: var(--brand-tint); color: var(--brand); margin-bottom: 16px; }
.ict-feat-card .ict-ic svg { width: 22px; height: 22px; }
.ict-feat-card h4 { font-size: 18.5px; font-family: var(--font-display); font-weight: 700; margin: 0; }
.ict-feat-card p { color: var(--muted); font-size: 14.5px; margin-top: 7px; line-height: 1.55; margin-bottom: 0; }

/* ================================================================
   MODES / TABS
   ================================================================ */
.ict-modes { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(28px,4vw,56px); align-items: center; }
.ict-tabs { display: flex; flex-direction: column; gap: 10px; }
.ict-tab {
  text-align: left;
  cursor: pointer;
  padding: 20px 22px;
  border-radius: var(--r);
  background: var(--surface);
  border: 1px solid var(--border);
  transition: all .2s;
  display: flex;
  gap: 15px;
  align-items: flex-start;
  font-family: var(--font-body);
  width: 100%;
}
.ict-tab:hover { border-color: var(--brand-300); }
.ict-tab.active { border-color: var(--brand); background: var(--brand-tint); box-shadow: 0 1px 2px rgba(16,18,40,.06); }
.ict-tab .ict-tab-ic { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; background: var(--surface-2); color: var(--muted); flex: none; transition: all .2s; }
.ict-tab.active .ict-tab-ic { background: var(--brand); color: #fff; }
.ict-tab .ict-tab-ic svg { width: 20px; height: 20px; }
.ict-tab h4 { font-size: 18px; margin: 0; font-family: var(--font-display); font-weight: 700; }
.ict-tab p { font-size: 14px; color: var(--muted); margin-top: 4px; margin-bottom: 0; }
.ict-tab.active h4 { color: var(--brand); }
.ict-mode-visual { position: relative; }

/* ================================================================
   INDUSTRY SOLUTIONS GRID
   ================================================================ */
.ict-ind-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.ict-ind-card { position: relative; padding: 24px 20px; border-radius: var(--r); background: var(--surface); border: 1px solid var(--border); transition: transform .22s, box-shadow .22s, border-color .22s; overflow: hidden; }
.ict-ind-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: var(--brand-300); }
.ict-ind-card .ict-ic { width: 50px; height: 50px; border-radius: 13px; background: var(--brand-tint); color: var(--brand); display: grid; place-items: center; margin-bottom: 16px; transition: all .25s; }
.ict-ind-card:hover .ict-ic { background: var(--brand); color: #fff; box-shadow: var(--shadow-brand); transform: rotate(-4deg); }
.ict-ind-card .ict-ic svg { width: 24px; height: 24px; }
.ict-ind-card h4 { font-size: 16.5px; font-family: var(--font-display); font-weight: 700; margin: 0; }
.ict-ind-card p { color: var(--muted); font-size: 13px; margin-top: 6px; line-height: 1.5; margin-bottom: 0; }
.ict-ind-card .ict-more { margin-top: 14px; font-size: 13px; font-weight: 700; color: var(--brand); display: inline-flex; align-items: center; gap: 5px; opacity: 0; transform: translateX(-4px); transition: opacity .2s, transform .2s; }
.ict-ind-card:hover .ict-more { opacity: 1; transform: none; }

/* ================================================================
   STATS BAND
   ================================================================ */
.ict-statband { background: var(--night); color: #fff; border-radius: var(--r-xl); padding: clamp(34px,5vw,60px); position: relative; overflow: hidden; }
.ict-statband::before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 85% 10%, oklch(0.55 var(--brand-c) var(--brand-h) / .55), transparent 50%); }
.ict-statband .ict-inner { position: relative; display: grid; grid-template-columns: repeat(4,1fr); gap: 26px; }
.ict-stat .ict-n { font-family: var(--font-display); font-weight: 700; font-size: clamp(34px,4vw,52px); letter-spacing: -.03em; background: linear-gradient(120deg,#fff, var(--accent)); -webkit-background-clip:text; background-clip:text; color: transparent; }
.ict-stat .ict-l { color: rgba(255,255,255,.65); font-size: 14.5px; margin-top: 6px; font-weight: 500; }

/* ================================================================
   RESELLER / SPLIT
   ================================================================ */
.ict-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,4vw,60px); align-items: center; }
.ict-tick-list { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; padding: 0; list-style: none; }
.ict-tick-list li { display: flex; gap: 13px; align-items: flex-start; }
.ict-tick-list .ict-tk { width: 26px; height: 26px; border-radius: 8px; background: var(--brand-tint); color: var(--brand); display: grid; place-items: center; flex: none; margin-top: 1px; }
.ict-tick-list .ict-tk svg { width: 15px; height: 15px; }
.ict-tick-list b { font-weight: 700; font-family: var(--font-display); font-size: 16px; }
.ict-tick-list span { color: var(--muted); font-size: 14.5px; }
.ict-tick-list .ict-tx { display: flex; flex-direction: column; gap: 2px; }
.ict-pill-tag { display:inline-flex; align-items:center; gap:7px; background: var(--brand-tint); color: var(--brand); font-weight:700; font-size:13px; padding:6px 13px; border-radius:var(--r-pill); }

/* ================================================================
   TESTIMONIAL SLIDER
   ================================================================ */
.ict-quote { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-xl); padding: clamp(30px,4vw,52px); box-shadow: var(--shadow); position: relative; }
.ict-quote blockquote { font-family: var(--font-display); font-weight: 600; font-size: clamp(20px,2.4vw,30px); line-height: 1.3; letter-spacing: -.02em; margin: 0; position: relative; }
.ict-quote .ict-by { display: flex; align-items: center; gap: 14px; margin-top: 28px; }
.ict-quote .ict-q-ava { width: 48px; height: 48px; border-radius: 50%; display:grid; place-items:center; font-size:15px; font-weight:700; color:#fff; background: linear-gradient(135deg,var(--brand-300),var(--brand)); flex:none; }
.ict-quote .ict-stars { color: #f6a609; letter-spacing: 3px; font-size: 15px; margin-bottom: 16px; display: block; }
.ict-tslider { position: relative; }
.ict-tslider-viewport { overflow: hidden; border-radius: var(--r-xl); }
.ict-tslider-track { display: flex; transition: transform .55s cubic-bezier(.5,.1,.2,1); }
.ict-tslide { flex: 0 0 100%; min-width: 100%; padding: 4px; }
.ict-tslider-ctrl { display: flex; align-items: center; justify-content: center; gap: 20px; margin-top: 30px; }
.ict-tarrow { width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--border-2); background: var(--surface); color: var(--ink); display: grid; place-items: center; cursor: pointer; transition: all .2s; }
.ict-tarrow:hover { background: var(--brand); border-color: var(--brand); color: #fff; transform: translateY(-2px); box-shadow: var(--shadow-brand); }
.ict-tarrow svg { width: 20px; height: 20px; }
.ict-tdots { display: flex; gap: 9px; }
.ict-tdot { width: 9px; height: 9px; border-radius: 50%; border: none; padding: 0; background: var(--border-2); cursor: pointer; transition: all .25s; }
.ict-tdot.active { background: var(--brand); width: 26px; border-radius: var(--r-pill); }

/* ================================================================
   CTA BAND
   ================================================================ */
.ict-cta-band { position: relative; overflow: hidden; border-radius: var(--r-xl); padding: clamp(44px,6vw,84px); text-align: center; background: linear-gradient(135deg, var(--brand-700), var(--brand)); color: #fff; }
.ict-cta-band::after { content:""; position:absolute; inset:0; background-image: linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px); background-size: 44px 44px; mask-image: radial-gradient(ellipse 70% 80% at 50% 0%, #000, transparent 70%); pointer-events:none; }
.ict-cta-band h2 { color: #fff !important; position: relative; font-family: var(--font-display) !important; font-size: clamp(32px, 4.4vw, 54px) !important; }
.ict-cta-band p { color: rgba(255,255,255,.82); position: relative; margin: 16px auto 0; max-width: 52ch; margin-bottom: 0; }
.ict-cta-band .ict-hero-cta { justify-content: center; position: relative; margin-top: 28px; }

/* ================================================================
   PRICING PAGE
   ================================================================ */
.ict-toggle { display: inline-flex; align-items: center; gap: 12px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-pill); padding: 6px; }
.ict-toggle button { font-family: var(--font-body); font-weight: 600; font-size: 14.5px; padding: 9px 18px; border-radius: var(--r-pill); border: none; background: transparent; color: var(--muted); cursor: pointer; transition: all .2s; }
.ict-toggle button.active { background: var(--brand); color: #fff; box-shadow: 0 1px 2px rgba(16,18,40,.06); }
.ict-toggle .ict-save { font-size: 12px; color: var(--brand); font-weight: 700; }

.ict-plans { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; align-items: stretch; }
.ict-plan { display: flex; flex-direction: column; padding: 24px; border-radius: var(--r-lg); background: var(--surface); border: 1px solid var(--border); position: relative; transition: transform .2s, box-shadow .2s; }
.ict-plan:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.ict-plan.ict-plan-feat { border-color: var(--brand); box-shadow: var(--shadow-brand); }
.ict-plan .ict-badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--brand); color: #fff; font-size: 12px; font-weight: 700; padding: 5px 15px; border-radius: var(--r-pill); letter-spacing: .03em; white-space: nowrap; }
.ict-plan .ict-pname { font-family: var(--font-display); font-weight: 700; font-size: 19px; }
.ict-plan .ict-pdesc { color: var(--muted); font-size: 13.5px; margin-top: 6px; min-height: 36px; }
.ict-plan .ict-price { display: flex; align-items: flex-end; gap: 4px; margin: 16px 0 4px; }
.ict-plan .ict-price .ict-amt { font-family: var(--font-display); font-weight: 700; font-size: 38px; letter-spacing: -.03em; }
.ict-plan .ict-price .ict-per { color: var(--muted); font-size: 14px; font-weight: 600; margin-bottom: 6px; }
.ict-plan .ict-pnote { font-size: 13px; color: var(--faint); }
.ict-plan .ict-btn { width: 100%; justify-content: center; margin: 22px 0; }
.ict-plan .ict-plist { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.ict-plan .ict-plist li { display: flex; gap: 10px; align-items: flex-start; font-size: 14.5px; color: var(--ink-2); }
.ict-plan .ict-plist svg { width: 17px; height: 17px; color: var(--brand); flex: none; margin-top: 2px; }
.ict-plan .ict-plist li.ict-off { color: var(--faint); }
.ict-plan .ict-plist li.ict-off svg { color: var(--faint); }

.ict-rate-tabs { display: inline-flex; gap: 6px; background: var(--surface-2); border:1px solid var(--border); border-radius: var(--r-pill); padding: 6px; }
.ict-rate-tabs button { font-family: var(--font-body); font-weight: 600; font-size: 14px; padding: 9px 20px; border-radius: var(--r-pill); border: none; background: transparent; color: var(--muted); cursor: pointer; display:inline-flex; align-items:center; gap:8px; transition: all .2s; }
.ict-rate-tabs button svg { width: 16px; height: 16px; }
.ict-rate-tabs button.active { background: var(--surface); color: var(--brand); box-shadow: 0 1px 2px rgba(16,18,40,.06); }
.ict-rate-table { width: 100%; border-collapse: collapse; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.ict-rate-table th { text-align: left; font-family: var(--font-body); font-size: 12.5px; text-transform: uppercase; letter-spacing: .05em; color: var(--faint); font-weight: 700; padding: 15px 20px; background: var(--surface-2); }
.ict-rate-table th.r, .ict-rate-table td.r { text-align: right; }
.ict-rate-table td { padding: 14px 20px; border-top: 1px solid var(--border); font-size: 15px; }
.ict-rate-table tr:hover td { background: var(--surface-2); }
.ict-rate-table .ict-flag { width: 22px; height: 16px; border-radius: 3px; display: inline-block; margin-right: 11px; vertical-align: middle; box-shadow: 0 1px 2px rgba(16,18,40,.06); }
.ict-rate-table .ict-ramt { font-family: var(--font-display); font-weight: 700; }

.ict-cmp { width: 100%; border-collapse: collapse; }
.ict-cmp th, .ict-cmp td { padding: 16px 18px; border-bottom: 1px solid var(--border); text-align: center; }
.ict-cmp th { font-family: var(--font-display); }
.ict-cmp td:first-child, .ict-cmp th:first-child { text-align: left; font-weight: 600; }
.ict-cmp thead th { font-size: 16px; }
.ict-cmp thead th.ict-hl { color: var(--brand); }
.ict-cmp tbody td svg { width: 19px; height: 19px; color: var(--brand); }
.ict-cmp .ict-x { color: var(--border-2); }
.ict-cmp tr td.ict-section-h { background: var(--surface-2); font-family: var(--font-display); font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); }

.ict-faq-item { border-bottom: 1px solid var(--border); }
.ict-faq-q { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 22px 0; display: flex; justify-content: space-between; gap: 20px; align-items: center; font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--ink); }
.ict-faq-q .ict-pm { width: 30px; height: 30px; border-radius: 9px; border: 1px solid var(--border); display: grid; place-items: center; flex: none; transition: all .2s; color: var(--brand); }
.ict-faq-item.open .ict-faq-q .ict-pm { background: var(--brand); color: #fff; border-color: var(--brand); transform: rotate(45deg); }
.ict-faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.ict-faq-a p { color: var(--muted); padding-bottom: 22px; max-width: 70ch; margin-bottom: 0; }

/* ================================================================
   DIVI THEME BUILDER FOOTER (et-l--footer)
   Custom footer injected via et_pb_code module — uses ict-ftb-* classes
   ================================================================ */

/* Remove Divi's default padding/margin on the footer section wrapper */
.et-l--footer .et_pb_section { padding: 0 !important; margin: 0 !important; }
.et-l--footer .et_pb_row { max-width: 100% !important; width: 100% !important; padding: 0 !important; margin: 0 !important; }
.et-l--footer .et_pb_column { padding: 0 !important; margin: 0 !important; }

.ict-ftb-outer {
  background: oklch(0.21 0.028 274);
  color: rgba(255,255,255,.78);
  font-family: var(--font-body);
  padding-top: clamp(50px,6vw,80px);
}
.ict-ftb-wrap {
  max-width: 1280px;
  margin-inline: auto;
  padding-inline: clamp(20px,4vw,56px);
}
.ict-ftb-cols {
  display: grid;
  grid-template-columns: 1.5fr repeat(4, 1fr);
  gap: clamp(24px,3vw,40px);
  padding-bottom: 44px;
}
.ict-ftb-brand-link {
  display: inline-block;
  margin-bottom: 18px;
  text-decoration: none;
}
.ict-ftb-logo-img {
  height: 52px;
  width: auto;
  display: block;
}
.ict-ftb-desc {
  color: rgba(255,255,255,.58);
  font-size: 14px;
  line-height: 1.65;
  max-width: 30ch;
  margin: 0 0 20px;
}
.ict-ftb-soc { display: flex; gap: 10px; }
.ict-ftb-soc-link {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(255,255,255,.08);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.85);
  text-decoration: none;
  transition: background .2s, color .2s;
}
.ict-ftb-soc-link:hover { background: oklch(0.55 0.165 268); color: #fff; }
.ict-ftb-soc svg { width: 17px; height: 17px; display: block; }
.ict-ftb-heading {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 12.5px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin: 0 0 16px;
}
.ict-ftb-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.ict-ftb-list .ict-ftb-item {
  list-style: none !important;
  list-style-type: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: none !important;
}
.ict-ftb-list .ict-ftb-item::before,
.ict-ftb-list .ict-ftb-item::marker {
  content: none !important;
  display: none !important;
}
.ict-ftb-list a {
  color: rgba(255,255,255,.75);
  font-size: 14.5px;
  text-decoration: none;
  transition: color .18s;
}
.ict-ftb-list a:hover { color: oklch(0.78 0.14 200); }
.ict-ftb-plain { color: rgba(255,255,255,.75); font-size: 14.5px; }
.ict-ftb-muted { color: rgba(255,255,255,.42) !important; font-size: 13px !important; }
.ict-ftb-legal {
  border-top: 1px solid rgba(255,255,255,.12);
  padding-block: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  color: rgba(255,255,255,.5);
  font-size: 13px;
}
.ict-ftb-legal-links { display: flex; gap: 20px; }
.ict-ftb-legal-links a { color: rgba(255,255,255,.65); text-decoration: none; transition: color .18s; }
.ict-ftb-legal-links a:hover { color: oklch(0.78 0.14 200); }

/* Responsive footer */
@media (max-width: 900px) {
  .ict-ftb-cols { grid-template-columns: 1fr 1fr; }
  .ict-ftb-col-brand { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
  .ict-ftb-cols { grid-template-columns: 1fr 1fr; }
  .ict-ftb-legal { flex-direction: column; align-items: flex-start; }
}

/* ================================================================
   SCROLL REVEAL
   ================================================================ */
[data-reveal] {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
}
[data-reveal].in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { [data-reveal]{ opacity:1; transform:none; } }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 980px) {
  .ict-hero-inner { grid-template-columns: 1fr; }
  .ict-hero-visual { order: -1; }
  .ict-modes { grid-template-columns: 1fr; }
  .ict-split { grid-template-columns: 1fr; }
  .ict-statband .ict-inner { grid-template-columns: repeat(2,1fr); }
  .ict-ind-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .ict-grid-3, .ict-grid-4, .ict-grid-2 { grid-template-columns: 1fr !important; }
  .ict-plans { grid-template-columns: repeat(2, 1fr) !important; }
  .ict-mock-float { display: none; }
  .ict-rate-table th:nth-child(2), .ict-rate-table td:nth-child(2) { display: none; }
}
@media (max-width: 560px) {
  .ict-ind-grid { grid-template-columns: repeat(2, 1fr); }
}
