/* ============================================================
   AIWB — MAIN FRONTEND CSS
   AI Website Experience Builder
   ============================================================ */

/* ── Design Tokens ────────────────────────────────────────── */
:root {
  --aiwb-primary:       #00d4ff;
  --aiwb-secondary:     #7c3aed;
  --aiwb-accent:        #00b8d9;
  --aiwb-bg:            #080c14;
  --aiwb-surface:       #0d1220;
  --aiwb-surface2:      #121929;
  --aiwb-surface3:      #1a2436;
  --aiwb-border:        rgba(255,255,255,0.07);
  --aiwb-border-glow:   rgba(0,212,255,0.25);
  --aiwb-text:          #e8edf7;
  --aiwb-text-muted:    #6b7a99;
  --aiwb-text-dim:      #3d4f6b;
  --aiwb-radius:        12px;
  --aiwb-radius-lg:     20px;
  --aiwb-radius-xl:     28px;
  --aiwb-font-display:  'Syne', sans-serif;
  --aiwb-font-body:     'DM Sans', sans-serif;
  --aiwb-shadow-sm:     0 2px 12px rgba(0,0,0,0.4);
  --aiwb-shadow-md:     0 8px 32px rgba(0,0,0,0.5);
  --aiwb-shadow-glow:   0 0 40px rgba(0,212,255,0.12);
  --aiwb-transition:    0.32s cubic-bezier(0.4, 0, 0.2, 1);
  --aiwb-transition-fast: 0.18s cubic-bezier(0.4, 0, 0.2, 1);
  --aiwb-conf-width:    380px;
}

/* ── Root Container ───────────────────────────────────────── */
.aiwb-root {
  position:         relative;
  width:            100%;
  background:       var(--aiwb-bg);
  color:            var(--aiwb-text);
  font-family:      var(--aiwb-font-body);
  font-size:        15px;
  line-height:      1.6;
  overflow:         hidden;
  padding:          80px 0 60px;
  box-sizing:       border-box;
}

.aiwb-root *,
.aiwb-root *::before,
.aiwb-root *::after {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
}

/* ── Ambient Background ───────────────────────────────────── */
.aiwb-bg-layer {
  position:  absolute;
  inset:     0;
  z-index:   0;
  pointer-events: none;
}

.aiwb-grid-overlay {
  position:  absolute;
  inset:     0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
  animation: aiwb-grid-shift 20s linear infinite;
}

@keyframes aiwb-grid-shift {
  0%   { background-position: 0 0, 0 0; }
  100% { background-position: 48px 48px, 48px 48px; }
}

.aiwb-orb {
  position:      absolute;
  border-radius: 50%;
  filter:        blur(80px);
  opacity:       0.18;
  pointer-events:none;
  animation:     aiwb-orb-float 8s ease-in-out infinite alternate;
}

.aiwb-orb-1 {
  width:      600px;
  height:     600px;
  top:        -200px;
  left:       -100px;
  background: radial-gradient(circle, var(--aiwb-primary) 0%, transparent 70%);
  animation-delay: 0s;
  animation-duration: 10s;
}

.aiwb-orb-2 {
  width:      500px;
  height:     500px;
  top:        40%;
  right:      -80px;
  background: radial-gradient(circle, var(--aiwb-secondary) 0%, transparent 70%);
  animation-delay: 3s;
  animation-duration: 12s;
}

.aiwb-orb-3 {
  width:      400px;
  height:     400px;
  bottom:     -100px;
  left:       30%;
  background: radial-gradient(circle, #0066ff 0%, transparent 70%);
  animation-delay: 6s;
  animation-duration: 9s;
}

@keyframes aiwb-orb-float {
  0%   { transform: translate(0, 0) scale(1); }
  100% { transform: translate(30px, -30px) scale(1.08); }
}

/* ── Cursor Glow ──────────────────────────────────────────── */
.aiwb-cursor-glow {
  position:       fixed;
  width:          300px;
  height:         300px;
  border-radius:  50%;
  background:     radial-gradient(circle, rgba(0,212,255,0.08) 0%, transparent 70%);
  pointer-events: none;
  transform:      translate(-50%, -50%);
  z-index:        9999;
  transition:     opacity 0.3s ease;
  opacity:        0;
}

/* ── Section Header ───────────────────────────────────────── */
.aiwb-header {
  position:  relative;
  z-index:   2;
  text-align: center;
  padding:   0 24px 60px;
  max-width: 760px;
  margin:    0 auto;
}

.aiwb-header-badge {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  background:      rgba(0,212,255,0.08);
  border:          1px solid rgba(0,212,255,0.2);
  border-radius:   100px;
  padding:         6px 16px;
  font-size:       11px;
  font-weight:     500;
  letter-spacing:  0.12em;
  text-transform:  uppercase;
  color:           var(--aiwb-primary);
  margin-bottom:   24px;
}

.aiwb-badge-dot {
  width:        6px;
  height:       6px;
  border-radius:50%;
  background:   var(--aiwb-primary);
  animation:    aiwb-pulse-dot 2s ease-in-out infinite;
}

@keyframes aiwb-pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.4; transform: scale(0.7); }
}

.aiwb-headline {
  font-family:   var(--aiwb-font-display);
  font-size:     clamp(36px, 5vw, 64px);
  font-weight:   800;
  line-height:   1.1;
  letter-spacing:-0.02em;
  margin:        0 0 20px;
  background:    linear-gradient(135deg, #ffffff 0%, var(--aiwb-primary) 60%, var(--aiwb-secondary) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.aiwb-subheadline {
  font-size:   18px;
  color:       var(--aiwb-text-muted);
  font-weight: 300;
  margin:      0;
  line-height: 1.7;
}

/* ── Main Interface Layout ────────────────────────────────── */
.aiwb-interface {
  position:      relative;
  z-index:       2;
  display:       grid;
  grid-template-columns: var(--aiwb-conf-width) 1fr;
  gap:           24px;
  max-width:     1440px;
  margin:        0 auto;
  padding:       0 24px;
  align-items:   start;
}

/* ── Configurator Panel ───────────────────────────────────── */
.aiwb-configurator {
  display:          flex;
  flex-direction:   column;
  gap:              4px;
  background:       var(--aiwb-surface);
  border:           1px solid var(--aiwb-border);
  border-radius:    var(--aiwb-radius-xl);
  padding:          8px;
  position:         sticky;
  top:              24px;
  max-height:       calc(100vh - 48px);
  overflow-y:       auto;
  scrollbar-width:  thin;
  scrollbar-color:  var(--aiwb-surface3) transparent;
}

.aiwb-configurator::-webkit-scrollbar { width: 4px; }
.aiwb-configurator::-webkit-scrollbar-track { background: transparent; }
.aiwb-configurator::-webkit-scrollbar-thumb { background: var(--aiwb-surface3); border-radius: 4px; }

.aiwb-config-section {
  padding:       16px;
  border-radius: var(--aiwb-radius);
  transition:    background var(--aiwb-transition-fast);
}

.aiwb-config-section:hover {
  background: rgba(255,255,255,0.02);
}

.aiwb-section-label {
  display:       flex;
  align-items:   center;
  gap:           10px;
  font-family:   var(--aiwb-font-display);
  font-size:     11px;
  font-weight:   700;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:         var(--aiwb-text-muted);
  margin-bottom: 14px;
}

.aiwb-step-num {
  display:        flex;
  align-items:    center;
  justify-content:center;
  width:          22px;
  height:         22px;
  border-radius:  6px;
  background:     rgba(0,212,255,0.1);
  color:          var(--aiwb-primary);
  font-size:      10px;
  font-weight:    800;
  flex-shrink:    0;
}

/* Business Type Grid */
.aiwb-business-grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   6px;
}

.aiwb-biz-btn {
  padding:       8px 10px;
  border-radius: 8px;
  border:        1px solid var(--aiwb-border);
  background:    transparent;
  color:         var(--aiwb-text-muted);
  font-family:   var(--aiwb-font-body);
  font-size:     12px;
  font-weight:   500;
  cursor:        pointer;
  transition:    all var(--aiwb-transition-fast);
  text-align:    left;
  line-height:   1.3;
}

.aiwb-biz-btn:hover {
  border-color: rgba(0,212,255,0.3);
  color:        var(--aiwb-text);
  background:   rgba(0,212,255,0.05);
}

.aiwb-biz-btn.active {
  border-color: var(--aiwb-primary);
  background:   rgba(0,212,255,0.1);
  color:        var(--aiwb-primary);
  box-shadow:   0 0 12px rgba(0,212,255,0.15);
}

/* Style Grid */
.aiwb-style-grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   6px;
}

.aiwb-style-btn {
  padding:       8px 12px;
  border-radius: 8px;
  border:        1px solid var(--aiwb-border);
  background:    transparent;
  color:         var(--aiwb-text-muted);
  font-family:   var(--aiwb-font-body);
  font-size:     12px;
  font-weight:   500;
  cursor:        pointer;
  transition:    all var(--aiwb-transition-fast);
  text-align:    center;
}

.aiwb-style-btn:hover {
  border-color: rgba(0,212,255,0.3);
  color:        var(--aiwb-text);
  background:   rgba(0,212,255,0.04);
}

.aiwb-style-btn.active {
  border-color: var(--aiwb-primary);
  background:   rgba(0,212,255,0.1);
  color:        var(--aiwb-primary);
}

/* Palette Row */
.aiwb-palette-row {
  display:   flex;
  flex-wrap: wrap;
  gap:       8px;
  align-items: center;
}

.aiwb-palette-btn {
  width:         36px;
  height:        36px;
  border-radius: 50%;
  border:        2px solid transparent;
  cursor:        pointer;
  padding:       3px;
  background:    linear-gradient(var(--aiwb-surface), var(--aiwb-surface)) padding-box,
                 linear-gradient(135deg, var(--pal-p), var(--pal-s)) border-box;
  transition:    all var(--aiwb-transition-fast);
  position:      relative;
}

.aiwb-palette-btn:hover {
  transform: scale(1.15);
}

.aiwb-palette-btn.active {
  transform:  scale(1.2);
  box-shadow: 0 0 16px var(--pal-p);
}

.aiwb-palette-btn.active::after {
  content:        '';
  position:       absolute;
  inset:          -4px;
  border-radius:  50%;
  border:         1px solid var(--pal-p);
  opacity:        0.6;
}

.aiwb-swatch-inner {
  display:       block;
  width:         100%;
  height:        100%;
  border-radius: 50%;
  background:    linear-gradient(135deg, var(--pal-p), var(--pal-s));
}

/* Layout Grid */
.aiwb-layout-grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   6px;
}

.aiwb-layout-btn {
  padding:       8px 10px;
  border-radius: 8px;
  border:        1px solid var(--aiwb-border);
  background:    transparent;
  color:         var(--aiwb-text-muted);
  font-family:   var(--aiwb-font-body);
  font-size:     12px;
  font-weight:   500;
  cursor:        pointer;
  transition:    all var(--aiwb-transition-fast);
  text-align:    center;
}

.aiwb-layout-btn:hover {
  border-color: rgba(0,212,255,0.3);
  color:        var(--aiwb-text);
  background:   rgba(0,212,255,0.04);
}

.aiwb-layout-btn.active {
  border-color: var(--aiwb-primary);
  background:   rgba(0,212,255,0.1);
  color:        var(--aiwb-primary);
}

/* Company Name Input */
.aiwb-input-wrap {
  position: relative;
}

.aiwb-text-input {
  width:         100%;
  padding:       12px 44px 12px 16px;
  background:    var(--aiwb-surface2);
  border:        1px solid var(--aiwb-border);
  border-radius: 10px;
  color:         var(--aiwb-text);
  font-family:   var(--aiwb-font-body);
  font-size:     14px;
  outline:       none;
  transition:    all var(--aiwb-transition-fast);
}

.aiwb-text-input::placeholder { color: var(--aiwb-text-dim); }
.aiwb-text-input:focus {
  border-color: var(--aiwb-primary);
  box-shadow:   0 0 0 3px rgba(0,212,255,0.1);
}

.aiwb-input-icon {
  position:  absolute;
  right:     14px;
  top:       50%;
  transform: translateY(-50%);
  color:     var(--aiwb-text-dim);
  width:     16px;
  height:    16px;
  pointer-events: none;
}

/* Features Grid */
.aiwb-features-grid {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   6px;
}

.aiwb-feature-check {
  display:     flex;
  align-items: center;
  gap:         8px;
  cursor:      pointer;
  padding:     6px 8px;
  border-radius: 8px;
  border:      1px solid transparent;
  transition:  all var(--aiwb-transition-fast);
}

.aiwb-feature-check:hover {
  background:  rgba(255,255,255,0.03);
  border-color: var(--aiwb-border);
}

.aiwb-feature-input {
  position: absolute;
  opacity:  0;
  width:    0;
  height:   0;
}

.aiwb-check-box {
  width:          18px;
  height:         18px;
  border-radius:  5px;
  border:         1px solid var(--aiwb-border);
  background:     var(--aiwb-surface2);
  display:        flex;
  align-items:    center;
  justify-content:center;
  flex-shrink:    0;
  transition:     all var(--aiwb-transition-fast);
  color:          transparent;
}

.aiwb-check-box svg {
  width:  10px;
  height: 10px;
}

.aiwb-feature-input:checked + .aiwb-check-box {
  background:   var(--aiwb-primary);
  border-color: var(--aiwb-primary);
  color:        #000;
  box-shadow:   0 0 10px rgba(0,212,255,0.3);
}

.aiwb-check-label {
  font-size:   12px;
  font-weight: 500;
  color:       var(--aiwb-text-muted);
  transition:  color var(--aiwb-transition-fast);
  line-height: 1.2;
}

.aiwb-feature-check:has(.aiwb-feature-input:checked) .aiwb-check-label {
  color: var(--aiwb-text);
}

/* Mode Buttons */
.aiwb-toggle-row {
  display: flex;
  gap:     8px;
}

.aiwb-mode-btn {
  display:       flex;
  align-items:   center;
  gap:           7px;
  flex:          1;
  justify-content: center;
  padding:       10px;
  border-radius: 10px;
  border:        1px solid var(--aiwb-border);
  background:    transparent;
  color:         var(--aiwb-text-muted);
  font-family:   var(--aiwb-font-body);
  font-size:     13px;
  font-weight:   500;
  cursor:        pointer;
  transition:    all var(--aiwb-transition-fast);
}

.aiwb-mode-btn:hover {
  border-color: rgba(0,212,255,0.3);
  color:        var(--aiwb-text);
}

.aiwb-mode-btn.active {
  border-color: var(--aiwb-primary);
  background:   rgba(0,212,255,0.08);
  color:        var(--aiwb-primary);
}

/* CTA Section */
.aiwb-cta-wrap {
  padding:       16px;
  margin-top:    4px;
}

.aiwb-generate-btn {
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             10px;
  width:           100%;
  padding:         16px 24px;
  border-radius:   12px;
  border:          none;
  background:      linear-gradient(135deg, var(--aiwb-primary) 0%, var(--aiwb-secondary) 100%);
  color:           #fff;
  font-family:     var(--aiwb-font-display);
  font-size:       15px;
  font-weight:     700;
  letter-spacing:  0.02em;
  cursor:          pointer;
  position:        relative;
  overflow:        hidden;
  transition:      all var(--aiwb-transition);
  box-shadow:      0 4px 24px rgba(0,212,255,0.25), 0 2px 8px rgba(0,0,0,0.3);
}

.aiwb-generate-btn::before {
  content:    '';
  position:   absolute;
  inset:      0;
  background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 60%);
  opacity:    0;
  transition: opacity var(--aiwb-transition-fast);
}

.aiwb-generate-btn:hover {
  transform:  translateY(-2px);
  box-shadow: 0 8px 40px rgba(0,212,255,0.35), 0 4px 16px rgba(0,0,0,0.4);
}

.aiwb-generate-btn:hover::before { opacity: 1; }
.aiwb-generate-btn:active { transform: translateY(0); }

.aiwb-generate-btn.loading {
  pointer-events: none;
  opacity: 0.8;
}

.aiwb-btn-icon {
  display:    flex;
  transition: transform var(--aiwb-transition-fast);
}

.aiwb-generate-btn:hover .aiwb-btn-icon { transform: translateX(4px); }

.aiwb-cta-note {
  text-align: center;
  font-size:  12px;
  color:      var(--aiwb-text-dim);
  margin:     10px 0 0;
}

/* ── Preview Panel ────────────────────────────────────────── */
.aiwb-preview-panel {
  display:        flex;
  flex-direction: column;
  gap:            16px;
  min-height:     700px;
}

/* Preview Toolbar */
.aiwb-preview-toolbar {
  display:         flex;
  align-items:     center;
  gap:             12px;
  padding:         10px 16px;
  background:      var(--aiwb-surface);
  border:          1px solid var(--aiwb-border);
  border-radius:   var(--aiwb-radius);
}

.aiwb-toolbar-left {
  display:     flex;
  gap:         6px;
  align-items: center;
}

.aiwb-toolbar-dot {
  width:         10px;
  height:        10px;
  border-radius: 50%;
}

.aiwb-toolbar-dot.red    { background: #ff5f57; }
.aiwb-toolbar-dot.yellow { background: #ffbd2e; }
.aiwb-toolbar-dot.green  { background: #28ca41; }

.aiwb-url-bar {
  flex:          1;
  display:       flex;
  align-items:   center;
  gap:           8px;
  padding:       6px 14px;
  background:    var(--aiwb-surface2);
  border-radius: 8px;
  border:        1px solid var(--aiwb-border);
  color:         var(--aiwb-text-muted);
  font-size:     12px;
  font-family:   monospace;
}

.aiwb-device-switcher {
  display: flex;
  gap:     4px;
}

.aiwb-device-btn {
  padding:       6px 8px;
  border-radius: 7px;
  border:        1px solid var(--aiwb-border);
  background:    transparent;
  color:         var(--aiwb-text-dim);
  cursor:        pointer;
  transition:    all var(--aiwb-transition-fast);
  display:       flex;
  align-items:   center;
}

.aiwb-device-btn:hover {
  color:        var(--aiwb-text);
  border-color: var(--aiwb-primary);
}

.aiwb-device-btn.active {
  background:   rgba(0,212,255,0.1);
  border-color: var(--aiwb-primary);
  color:        var(--aiwb-primary);
}

/* Preview Viewport */
.aiwb-preview-viewport {
  position:      relative;
  flex:          1;
  background:    var(--aiwb-surface);
  border:        1px solid var(--aiwb-border);
  border-radius: var(--aiwb-radius-lg);
  overflow:      hidden;
  min-height:    600px;
  transition:    all var(--aiwb-transition);
}

.aiwb-preview-viewport.device-desktop { width: 100%; }
.aiwb-preview-viewport.device-tablet  { max-width: 768px; margin: 0 auto; }
.aiwb-preview-viewport.device-mobile  { max-width: 390px; margin: 0 auto; }

/* Loader */
.aiwb-loader {
  position:        absolute;
  inset:           0;
  background:      var(--aiwb-surface);
  display:         flex;
  align-items:     center;
  justify-content: center;
  z-index:         10;
  opacity:         0;
  pointer-events:  none;
  transition:      opacity 0.4s ease;
}

.aiwb-loader.visible {
  opacity:        1;
  pointer-events: all;
}

.aiwb-loader-inner {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  gap:             24px;
  padding:         40px;
}

.aiwb-loader-ring {
  position: relative;
}

.aiwb-loader-arc {
  transform-origin: 50px 50px;
  animation: aiwb-spin 1.4s linear infinite;
}

@keyframes aiwb-spin {
  100% { transform: rotate(360deg); }
}

.aiwb-loader-steps {
  font-family:   var(--aiwb-font-display);
  font-size:     14px;
  font-weight:   600;
  color:         var(--aiwb-text-muted);
  text-align:    center;
  min-height:    22px;
  letter-spacing:0.01em;
}

.aiwb-loader-progress {
  width:         240px;
  height:        3px;
  background:    var(--aiwb-surface3);
  border-radius: 100px;
  overflow:      hidden;
}

.aiwb-loader-bar {
  height:        100%;
  border-radius: 100px;
  background:    linear-gradient(90deg, var(--aiwb-primary), var(--aiwb-secondary));
  width:         0%;
  transition:    width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Idle State */
.aiwb-preview-idle {
  position:        absolute;
  inset:           0;
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  justify-content: center;
  gap:             16px;
  padding:         40px;
  transition:      opacity 0.4s ease;
}

.aiwb-preview-idle.hidden {
  opacity:        0;
  pointer-events: none;
}

.aiwb-idle-icon { opacity: 0.3; }

.aiwb-idle-text {
  font-size:   15px;
  color:       var(--aiwb-text-muted);
  text-align:  center;
  margin:      0;
  line-height: 1.6;
}

.aiwb-idle-text strong { color: var(--aiwb-primary); font-weight: 600; }

.aiwb-idle-subtext {
  font-size:  13px;
  color:      var(--aiwb-text-dim);
  margin:     0;
}

/* Generated Preview */
.aiwb-preview-website {
  width:      100%;
  height:     100%;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
  opacity:    0;
  transition: opacity 0.6s ease;
}

.aiwb-preview-website.visible { opacity: 1; }
.aiwb-preview-website::-webkit-scrollbar { width: 4px; }
.aiwb-preview-website::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 4px; }

/* ── Pricing Card ─────────────────────────────────────────── */
.aiwb-pricing-card {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             20px;
  padding:         20px 24px;
  background:      var(--aiwb-surface);
  border:          1px solid var(--aiwb-border);
  border-radius:   var(--aiwb-radius-lg);
  backdrop-filter: blur(20px);
}

.aiwb-pricing-label {
  display:     block;
  font-size:   11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:       var(--aiwb-text-muted);
  margin-bottom: 4px;
}

.aiwb-pricing-value {
  display:     flex;
  align-items: baseline;
  gap:         4px;
}

.aiwb-currency {
  font-family: var(--aiwb-font-display);
  font-size:   20px;
  font-weight: 700;
  color:       var(--aiwb-text-muted);
  margin-top:  4px;
}

.aiwb-price-num {
  font-family:   var(--aiwb-font-display);
  font-size:     38px;
  font-weight:   800;
  background:    linear-gradient(135deg, var(--aiwb-primary), var(--aiwb-secondary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition:    all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.aiwb-price-num.updating {
  transform: scale(1.1);
  filter: brightness(1.3);
}

.aiwb-pricing-right {
  display:        flex;
  flex-direction: column;
  align-items:    flex-end;
  gap:            8px;
}

.aiwb-contact-btn {
  display:         flex;
  align-items:     center;
  gap:             8px;
  padding:         12px 24px;
  border-radius:   10px;
  background:      linear-gradient(135deg, var(--aiwb-primary) 0%, var(--aiwb-secondary) 100%);
  color:           #fff;
  font-family:     var(--aiwb-font-display);
  font-size:       14px;
  font-weight:     700;
  text-decoration: none;
  transition:      all var(--aiwb-transition);
  box-shadow:      0 4px 20px rgba(0,212,255,0.2);
}

.aiwb-contact-btn:hover {
  transform:  translateY(-2px);
  box-shadow: 0 8px 32px rgba(0,212,255,0.3);
  color:      #fff;
}

.aiwb-cta-note-sm {
  font-size: 11px;
  color:     var(--aiwb-text-dim);
}
