/* ============================================================
   ADHDaily Landing Page — styles.css
   2026 Futuristic Dark Design System
   ============================================================ */

/* ===================== DESIGN TOKENS ===================== */
:root {
  /* Brand */
  --accent:          #348a84;
  --accent-light:    #66bdb9;
  --accent-dark:     #216f6c;
  --accent-purple:   var(--accent-light);
  --accent-cyan:     #4fb8b2;
  --accent-emerald:  #10B981;
  --accent-amber:    #F59E0B;

  /* Dark theme (default) */
  --bg:              #0d0d0f;
  --bg-secondary:    #0a0a0f;
  --bg-tertiary:     #111118;
  --surface:         rgba(255,255,255,0.04);
  --surface-hover:   rgba(255,255,255,0.07);
  --surface-border:  rgba(255,255,255,0.08);
  --text-primary:    #F8FAFC;
  --text-secondary:  #94A3B8;
  --text-tertiary:   #475569;
  --nav-bg:          rgba(13,13,15,0.85);
  --glass-bg:        rgba(255,255,255,0.04);
  --glass-border:    rgba(255,255,255,0.08);
  --glow-color:      rgba(52,138,132,0.25);
  --glow-strong:     rgba(52,138,132,0.5);
  --shadow-color:    rgba(0,0,0,0.5);
  --input-bg:        rgba(255,255,255,0.05);
  --input-border:    rgba(255,255,255,0.1);
  --phone-frame:     #191924;
  --phone-inner:     #0d0d15;

  /* Typography */
  --font-body:       'Inter', system-ui, sans-serif;
  --font-display:    'Space Grotesk', system-ui, sans-serif;

  /* Sizes */
  --nav-h:           72px;
  --radius-sm:       8px;
  --radius-md:       14px;
  --radius-lg:       22px;
  --radius-xl:       32px;
  --radius-full:     9999px;

  /* Transitions */
  --ease-out:        cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring:     cubic-bezier(0.34, 1.56, 0.64, 1);
  --t-fast:          0.15s;
  --t-normal:        0.25s;
  --t-slow:          0.5s;
}

/* ===================== LIGHT THEME ===================== */
[data-theme="light"] {
  --bg:              #F8FAFF;
  --bg-secondary:    #EEF2FF;
  --bg-tertiary:     #E0E7FF;
  --surface:         rgba(0,0,0,0.03);
  --surface-hover:   rgba(0,0,0,0.06);
  --surface-border:  rgba(0,0,0,0.08);
  --text-primary:    #0F172A;
  --text-secondary:  #475569;
  --text-tertiary:   #94A3B8;
  --nav-bg:          rgba(248,250,255,0.90);
  --glass-bg:        rgba(255,255,255,0.7);
  --glass-border:    rgba(52,138,132,0.15);
  --glow-color:      rgba(52,138,132,0.15);
  --glow-strong:     rgba(52,138,132,0.3);
  --shadow-color:    rgba(15,23,42,0.1);
  --input-bg:        rgba(255,255,255,0.8);
  --input-border:    rgba(52,138,132,0.2);
  --phone-frame:     #DDE4FF;
  --phone-inner:     #EEF2FF;
}

/* ===================== RESET & BASE ===================== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text-primary);
  line-height: 1.6;
  overflow-x: hidden;
  transition: background var(--t-slow) var(--ease-out),
              color var(--t-slow) var(--ease-out);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; display: block; }
a  { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }

/* ===================== SCROLLBAR ===================== */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb {
  background: var(--accent);
  border-radius: var(--radius-full);
}

/* ===================== UTILITIES ===================== */
.container {
  width: 100%;
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: clamp(16px, 5vw, 64px);
}

.accent { color: var(--accent); }

/* ===================== BUTTONS ===================== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 600;
  border-radius: var(--radius-full);
  transition: transform var(--t-fast) var(--ease-spring),
              box-shadow var(--t-normal) var(--ease-out),
              background var(--t-normal) var(--ease-out),
              color var(--t-normal) var(--ease-out);
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  letter-spacing: -0.01em;
}

.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(255,255,255,0.25) 0%, transparent 70%);
  opacity: 0;
  transition: opacity var(--t-normal);
}
.btn:hover::before  { opacity: 1; }
.btn:active { transform: scale(0.97); }

/* Sizes */
.btn--sm  { font-size: 0.8125rem; padding: 8px 18px; }
.btn--lg  { font-size: 1rem;      padding: 15px 30px; }
.btn--full { width: 100%; justify-content: center; }

/* Variants */
.btn--primary {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-purple) 100%);
  color: #fff;
  box-shadow: 0 0 20px var(--glow-color), 0 4px 12px rgba(0,0,0,0.3);
}
.btn--primary:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 0 40px var(--glow-strong), 0 8px 24px rgba(0,0,0,0.4);
}

.btn--ghost {
  background: var(--glass-bg);
  color: var(--text-primary);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(12px);
}
.btn--ghost:hover {
  transform: translateY(-2px);
  border-color: var(--accent);
  box-shadow: 0 0 20px var(--glow-color);
}

/* ===================== SECTION HEADERS ===================== */
.section-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(52,138,132,0.1);
  border: 1px solid rgba(52,138,132,0.2);
  padding: 5px 14px;
  border-radius: var(--radius-full);
  margin-bottom: 16px;
}

.section-header {
  text-align: center;
  max-width: 640px;
  margin: 0 auto 64px;
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.15;
  color: var(--text-primary);
  margin-bottom: 16px;
}

.section-subtitle {
  font-size: clamp(0.9375rem, 2vw, 1.0625rem);
  color: var(--text-secondary);
  line-height: 1.7;
}

/* ===================== SCROLL REVEAL ===================== */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.75s var(--ease-out), transform 0.75s var(--ease-out);
}
.reveal.reveal--right {
  transform: translateX(40px);
}
.reveal.visible {
  opacity: 1;
  transform: translate(0, 0);
}

/* ===================== NAVIGATION ===================== */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: var(--nav-h);
  background: var(--nav-bg);
  backdrop-filter: blur(24px) saturate(1.8);
  -webkit-backdrop-filter: blur(24px) saturate(1.8);
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-normal), background var(--t-slow), box-shadow var(--t-normal);
}

.nav.scrolled {
  border-bottom-color: var(--surface-border);
  box-shadow: 0 4px 40px rgba(0,0,0,0.3);
}

.nav__container {
  display: flex;
  align-items: center;
  gap: 16px;
  height: 100%;
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: clamp(16px, 5vw, 48px);
}

.nav__logo {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  flex-shrink: 0;
}
.nav__logo-icon {
  display: flex;
  align-items: center;
  filter: drop-shadow(0 0 6px var(--accent));
}

/* Logo image in header */
.nav__logo-img {
  height: 36px;
  width: auto;
  display: block;
  filter: drop-shadow(0 6px 14px rgba(52,138,132,0.22));
}
.nav__logo-text {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--text-primary);
}

.nav__links {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
}

.nav__link {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
  padding: 6px 14px;
  border-radius: var(--radius-full);
  transition: color var(--t-fast), background var(--t-fast);
}
.nav__link:hover {
  color: var(--text-primary);
  background: var(--surface);
}

.nav__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: 16px;
}

/* Theme Toggle */
.theme-toggle {
  width: 56px;
  height: 28px;
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
}
.theme-toggle__track {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 6px;
  width: 100%;
  height: 100%;
  background: var(--surface);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-full);
  transition: background var(--t-normal), border-color var(--t-normal);
  position: relative;
}
[data-theme="light"] .theme-toggle__track {
  background: rgba(52,138,132,0.15);
  border-color: rgba(52,138,132,0.3);
}
.theme-toggle__thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 22px;
  height: 22px;
  background: linear-gradient(135deg, var(--accent), var(--accent-purple));
  border-radius: var(--radius-full);
  transition: transform 0.35s var(--ease-spring), background var(--t-normal);
  box-shadow: 0 0 10px var(--glow-strong);
  z-index: 1;
}
[data-theme="light"] .theme-toggle__thumb {
  transform: translateX(28px);
}
.theme-toggle__icon {
  color: var(--text-secondary);
  position: relative;
  z-index: 0;
  flex-shrink: 0;
}
.theme-toggle__icon--sun  { color: var(--accent-amber); }
.theme-toggle__icon--moon { color: var(--accent-light); }

/* Hamburger */
.nav__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 6px;
}
.nav__hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--text-primary);
  border-radius: 2px;
  transition: transform var(--t-normal), opacity var(--t-normal);
}
.nav__hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__hamburger.open span:nth-child(2) { opacity: 0; }
.nav__hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.nav__mobile {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--nav-bg);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--surface-border);
  padding: 16px 24px 24px;
  transform: translateY(-8px);
  opacity: 0;
  transition: transform var(--t-normal) var(--ease-out), opacity var(--t-normal);
  pointer-events: none;
}
.nav__mobile.open {
  display: block;
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.nav__mobile ul { display: flex; flex-direction: column; gap: 4px; }
.nav__mobile .nav__link { display: block; padding: 10px 12px; font-size: 1rem; }

/* ===================== ORBS / BACKGROUND ===================== */
.orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  animation: orbFloat 12s ease-in-out infinite alternate;
}
.orb--1 {
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(52,138,132,0.18) 0%, transparent 70%);
  top: -200px; left: -100px;
  animation-duration: 14s;
}
.orb--2 {
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(52,138,132,0.14) 0%, transparent 70%);
  top: 100px; right: -150px;
  animation-duration: 10s;
  animation-delay: -5s;
}
.orb--3 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(6,182,212,0.10) 0%, transparent 70%);
  bottom: -100px; left: 40%;
  animation-duration: 16s;
  animation-delay: -8s;
}

@keyframes orbFloat {
  0%   { transform: translate(0, 0)    scale(1); }
  50%  { transform: translate(30px, -20px) scale(1.05); }
  100% { transform: translate(-20px, 30px) scale(0.98); }
}

/* ===================== HERO SECTION ===================== */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding-top: var(--nav-h);
  overflow: hidden;
}

.hero__orbs { position: absolute; inset: 0; }
.hero__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(52,138,132,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(52,138,132,0.05) 1px, transparent 1px);
  background-size: 60px 60px;
  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%);
}

.hero__container {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1200px;
  margin-inline: auto;
  padding: clamp(40px, 8vw, 100px) clamp(16px, 5vw, 64px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: clamp(32px, 6vw, 80px);
}

.hero__content { max-width: 560px; }

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-secondary);
  background: var(--surface);
  border: 1px solid var(--surface-border);
  padding: 6px 16px;
  border-radius: var(--radius-full);
  margin-bottom: 24px;
}
.hero__badge-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1);   box-shadow: 0 0 6px var(--accent); }
  50%       { opacity: 0.7; transform: scale(1.3); box-shadow: 0 0 14px var(--accent); }
}

.hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1.05;
  color: var(--text-primary);
  margin-bottom: 20px;
}
.hero__title-accent {
  background: linear-gradient(135deg, var(--accent), var(--accent-purple) 50%, var(--accent-cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero__subtitle {
  font-size: clamp(1rem, 2vw, 1.125rem);
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 36px;
  max-width: 440px;
}

.hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 48px;
}

.hero__stats {
  display: flex;
  align-items: center;
  gap: 0;
}
.hero__stat {
  display: flex;
  flex-direction: column;
  padding: 0 24px;
}
.hero__stat:first-child { padding-left: 0; }
.hero__stat-num {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.03em;
}
.hero__stat-label {
  font-size: 0.8125rem;
  color: var(--text-tertiary);
}
.hero__stat-divider {
  width: 1px;
  height: 36px;
  background: var(--surface-border);
  flex-shrink: 0;
}

/* ===================== PHONE MOCKUP ===================== */
.hero__mockup {
  display: flex;
  justify-content: center;
  align-items: center;
  perspective: 1200px;
}

.phone-mockup {
  position: relative;
  display: inline-flex;
}

/* Hero phone */
.phone-mockup--hero .phone-mockup__frame {
  width: 280px;
  height: 560px;
  background: var(--phone-frame);
  border-radius: 44px;
  padding: 14px 12px;
  position: relative;
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,0.1),
    0 0 0 1px rgba(0,0,0,0.5),
    0 40px 80px rgba(0,0,0,0.5),
    0 80px 120px rgba(0,0,0,0.3);
  animation: phoneTilt 8s ease-in-out infinite;
}

.phone-mockup--sm .phone-mockup__frame {
  width: 220px;
  height: 440px;
  background: var(--phone-frame);
  border-radius: 36px;
  padding: 12px 10px;
  position: relative;
  box-shadow:
    inset 0 0 0 1.5px rgba(255,255,255,0.08),
    0 0 0 1px rgba(0,0,0,0.4),
    0 26px 60px rgba(0,0,0,0.45);
  animation: phoneFloat 6s ease-in-out infinite;
}

@keyframes phoneTilt {
  0%,100% { transform: rotateY(-8deg) rotateX(3deg) translateY(0);   }
  50%      { transform: rotateY(2deg)  rotateX(-2deg) translateY(-12px); }
}
@keyframes phoneFloat {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-10px); }
}

.phone-mockup__screen {
  width: 100%;
  height: 100%;
  background: var(--phone-inner);
  border-radius: 32px;
  overflow: hidden;
  position: relative;
}
.phone-mockup--sm .phone-mockup__screen { border-radius: 22px; }

/* Screenshot image inside phone mockups */
.phone-screenshot {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: inherit;
  -webkit-user-select: none;
  user-select: none;
}

.phone-mockup__notch {
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 22px;
  background: var(--phone-frame);
  border-radius: 0 0 16px 16px;
  z-index: 10;
}
.phone-mockup--sm .phone-mockup__notch {
  top: 10px;
  width: 60px;
  height: 16px;
  border-radius: 0 0 12px 12px;
}

/* Physical buttons */
.phone-mockup__btn {
  position: absolute;
  background: var(--phone-frame);
  border-radius: 2px;
}
.phone-mockup__btn--vol-up    { width: 3px; height: 28px; left: -3px; top: 120px; }
.phone-mockup__btn--vol-down  { width: 3px; height: 28px; left: -3px; top: 160px; }
.phone-mockup__btn--power     { width: 3px; height: 40px; right: -3px; top: 140px; }

/* Glow rings */
.phone-mockup--hero .phone-mockup__glow {
  position: absolute;
  inset: -40px;
  background: radial-gradient(ellipse 60% 70% at 50% 60%, rgba(52,138,132,0.2) 0%, transparent 70%);
  pointer-events: none;
  border-radius: 50%;
  animation: glowPulse 4s ease-in-out infinite;
}
.phone-mockup--sm .phone-mockup__glow {
  position: absolute;
  inset: -24px;
  background: radial-gradient(ellipse 60% 70% at 50% 60%, rgba(52,138,132,0.12) 0%, transparent 70%);
  pointer-events: none;
  border-radius: 50%;
}

@keyframes glowPulse {
  0%,100% { opacity: 0.6; transform: scale(1); }
  50%      { opacity: 1;   transform: scale(1.05); }
}

/* ===================== APP SCREEN CONTENT ===================== */
.app-screen {
  width: 100%;
  height: 100%;
  padding: 36px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  font-size: 10px;
  background: linear-gradient(180deg, #0d0d1a 0%, #080814 100%);
}

.app-screen__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.app-screen__greeting { color: #64748B; font-size: 9px; }
.app-screen__name    { color: #F8FAFC; font-weight: 700; font-size: 13px; }

.app-screen__focus-card {
  background: linear-gradient(135deg, rgba(52,138,132,0.15), rgba(52,138,132,0.06));
  border: 1px solid rgba(52,138,132,0.2);
  border-radius: 14px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.app-screen__focus-label { color: #64748B; font-size: 9px; text-transform: uppercase; letter-spacing: 0.08em; }
.app-screen__timer { font-family: var(--font-display); font-size: 28px; font-weight: 700; color: #F8FAFC; letter-spacing: -0.04em; }
.app-screen__timer-bar {
  width: 100%;
  height: 3px;
  background: rgba(255,255,255,0.1);
  border-radius: 2px;
  overflow: hidden;
}
.app-screen__timer-fill {
  height: 100%;
  width: 68%;
  background: linear-gradient(90deg, var(--accent), var(--accent-light));
  border-radius: 2px;
}
.app-screen__start-btn {
  background: linear-gradient(135deg, var(--accent), var(--accent-light));
  color: #fff;
  border: none;
  border-radius: 20px;
  padding: 5px 16px;
  font-size: 9px;
  font-weight: 600;
  cursor: default;
}

.app-screen__tasks { display: flex; flex-direction: column; gap: 7px; }
.app-screen__task {
  display: flex;
  align-items: center;
  gap: 7px;
  color: #94A3B8;
  font-size: 9.5px;
  padding: 6px 8px;
  background: rgba(255,255,255,0.03);
  border-radius: 8px;
}
.app-screen__task--done { color: #64748B; text-decoration: line-through; }
.app-screen__check { color: #10B981; font-size: 10px; }
.app-screen__circle {
  width: 10px; height: 10px;
  border: 1.5px solid rgba(255,255,255,0.2);
  border-radius: 50%;
  flex-shrink: 0;
}

/* Focus screen (mockup carousel) */
.app-screen--focus {
  padding: 30px 14px 14px;
  align-items: center;
  gap: 8px;
  background: linear-gradient(180deg, #070711 0%, #0c0c1a 100%);
}
.app-screen__top-bar {
  width: 100%;
  display: flex;
  justify-content: space-between;
  color: #475569;
  font-size: 8px;
  margin-bottom: 4px;
}
.app-screen__section-title {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 700;
  color: #F8FAFC;
  letter-spacing: -0.02em;
  align-self: flex-start;
  width: 100%;
}
.app-screen__big-timer {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 700;
  color: #F8FAFC;
  letter-spacing: -0.04em;
}
.app-screen__ring {
  width: 80px;
  height: 80px;
  position: absolute;
  top: 80px;
  filter: drop-shadow(0 0 8px rgba(52,138,132,0.5));
}
.app-screen__focus-task {
  font-size: 8px;
  color: #64748B;
  text-align: center;
}

/* Capture screen */
.app-screen--capture {
  padding: 30px 12px 14px;
  background: linear-gradient(180deg, #070711 0%, #0c0c1a 100%);
}
.app-screen__capture-input {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(52,138,132,0.2);
  border-radius: 8px;
  padding: 8px;
  color: #475569;
  font-size: 9px;
}
.app-screen__tags { display: flex; gap: 5px; }
.app-screen__tag {
  font-size: 8px;
  padding: 3px 8px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  color: #64748B;
}
.app-screen__tag--active {
  background: rgba(52,138,132,0.2);
  border-color: rgba(52,138,132,0.4);
  color: var(--accent-light);
}
.app-screen__recent { display: flex; flex-direction: column; gap: 5px; }
.app-screen__thought {
  font-size: 8.5px;
  color: #94A3B8;
  padding: 6px 8px;
  background: rgba(255,255,255,0.03);
  border-radius: 7px;
  border-left: 2px solid rgba(52,138,132,0.3);
}

/* Plan screen */
.app-screen--plan {
  padding: 30px 12px 14px;
  background: linear-gradient(180deg, #070711 0%, #0c0c1a 100%);
}
.app-screen__time-block {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 8px;
  border-radius: 8px;
  font-size: 8.5px;
  color: #94A3B8;
  background: rgba(255,255,255,0.03);
  border-left: 2px solid transparent;
}
.app-screen__time {
  font-weight: 600;
  color: #475569;
  font-size: 8px;
  width: 28px;
  flex-shrink: 0;
}
.app-screen__block-name { color: #94A3B8; }
.app-screen__time-block--done { color: #475569; text-decoration: line-through; border-left-color: #10B981; }
.app-screen__time-block--active {
  background: rgba(52,138,132,0.1);
  border-left-color: #348a84;
  color: #F8FAFC;
}
.app-screen__time-block--active .app-screen__block-name { color: var(--accent-light); font-weight: 600; }

/* Review screen */
.app-screen--review {
  padding: 30px 12px 14px;
  align-items: center;
  background: linear-gradient(180deg, #070711 0%, #0c0c1a 100%);
}
.app-screen__score-label { font-size: 8px; color: #475569; text-transform: uppercase; letter-spacing: 0.08em; }
.app-screen__score {
  font-family: var(--font-display);
  font-size: 42px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--accent), var(--accent-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.04em;
  line-height: 1;
  margin: 4px 0;
}
.app-screen__bars { width: 100%; display: flex; flex-direction: column; gap: 6px; margin-top: 4px; }
.app-screen__bar-row { display: flex; align-items: center; gap: 6px; font-size: 8px; color: #64748B; }
.app-screen__bar-row > span { width: 28px; text-align: right; }
.app-screen__bar {
  flex: 1;
  height: 5px;
  background: rgba(255,255,255,0.07);
  border-radius: 3px;
  overflow: hidden;
}
.app-screen__bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-light));
  border-radius: 3px;
}

/* Settings screen */
.app-screen--settings {
  padding: 30px 12px 14px;
  background: linear-gradient(180deg, #070711 0%, #0c0c1a 100%);
}
.app-screen__setting-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px;
  border-radius: 8px;
  font-size: 9px;
  color: #94A3B8;
  background: rgba(255,255,255,0.03);
}
.app-screen__toggle {
  width: 24px;
  height: 13px;
  background: rgba(255,255,255,0.1);
  border-radius: 10px;
  position: relative;
  flex-shrink: 0;
}
.app-screen__toggle::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #475569;
  transition: transform 0.2s, background 0.2s;
}
.app-screen__toggle--on {
  background: rgba(52,138,132,0.3);
}
.app-screen__toggle--on::after {
  background: #348a84;
  transform: translateX(11px);
}

/* ===================== FEATURES SECTION ===================== */
.features {
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
}

.features__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 20px;
}

.feature-card {
  position: relative;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: transform var(--t-normal) var(--ease-spring),
              border-color var(--t-normal),
              box-shadow var(--t-normal);
  overflow: hidden;
}

.feature-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(52,138,132,0.5), transparent);
  opacity: 0;
  transition: opacity var(--t-normal);
}
.feature-card:hover { transform: translateY(-6px); }
.feature-card:hover::before { opacity: 1; }
.feature-card:hover {
  border-color: rgba(52,138,132,0.25);
  box-shadow: 0 20px 60px rgba(52,138,132,0.1), 0 0 0 1px rgba(52,138,132,0.1);
}

.feature-card__icon-wrap {
  width: 56px;
  height: 56px;
  background: rgba(52,138,132,0.08);
  border: 1px solid rgba(52,138,132,0.15);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  transition: background var(--t-normal), box-shadow var(--t-normal);
}
.feature-card:hover .feature-card__icon-wrap {
  background: rgba(52,138,132,0.14);
  box-shadow: 0 0 20px rgba(52,138,132,0.2);
}
.feature-card__icon { width: 32px; height: 32px; }
.feature-card__title {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin-bottom: 10px;
}
.feature-card__desc {
  font-size: 0.9rem;
  color: var(--text-secondary);
  line-height: 1.65;
  margin-bottom: 20px;
}
.feature-card__tag {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(52,138,132,0.1);
  padding: 3px 10px;
  border-radius: var(--radius-full);
}

/* ===================== MOCKUPS SECTION ===================== */
.mockups {
  padding: clamp(60px, 8vw, 120px) 0;
  overflow: hidden;
}

.mockups__carousel {
  position: relative;
  margin-top: 48px;
}

.mockups__track {
  display: flex;
  gap: clamp(24px, 4vw, 48px);
  padding: 40px clamp(16px, 5vw, 64px);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  /* center items on desktop */
  justify-content: center;
}
.mockups__track::-webkit-scrollbar { display: none; }

/* Static grid for the main mockups section (3-up visual showcase) */
.mockups__grid {
  display: flex;
  gap: clamp(20px, 4.5vw, 44px);
  justify-content: center;
  align-items: start;
  padding: 28px clamp(16px, 5vw, 64px);
  flex-wrap: nowrap;
}
.mockups__grid .mockup-item { flex: 0 0 calc(33.333% - 24px); max-width: 420px; }

/* Larger sizing specifically for the main 'See it in action' mockups */
#mockups .mockups__grid .mockup-item { max-width: 560px; }
#mockups .mockups__grid .phone-mockup--sm .phone-mockup__frame {
  width: 300px;
  height: 600px;
  border-radius: 48px;
  padding: 14px 12px;
  box-shadow:
    inset 0 0 0 1.5px rgba(255,255,255,0.08),
    0 32px 80px rgba(0,0,0,0.55);
}
#mockups .mockups__grid .phone-mockup--sm .phone-mockup__screen { border-radius: 36px; }

/* Ensure the pro carousel reuses track behavior but visually fits */
.mockups--pro .mockups__track { overflow: hidden; }

.mockup-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  flex-shrink: 0;
  scroll-snap-align: center;
}
.mockup-item__label {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: -0.01em;
}

.mockups__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding-top: 16px;
}
.mockups__btn {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--t-fast), border-color var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);
}
.mockups__btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  transform: scale(1.08);
  box-shadow: 0 0 16px var(--glow-color);
}

.mockups__dots {
  display: flex;
  gap: 8px;
}
.mockups__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--text-tertiary);
  cursor: pointer;
  transition: background var(--t-fast), transform var(--t-fast), width var(--t-normal) var(--ease-spring);
  border: none;
}
.mockups__dot.active {
  background: var(--accent);
  width: 20px;
  border-radius: 4px;
  box-shadow: 0 0 8px var(--accent);
}

/* ===================== REVIEWS SECTION ===================== */
.reviews {
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
}

.reviews__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: start;
}

.review-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  position: relative;
  transition: transform var(--t-normal) var(--ease-spring), box-shadow var(--t-normal);
}
.review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 60px var(--shadow-color);
}
.review-card--featured {
  border-color: rgba(52,138,132,0.25);
  background: linear-gradient(145deg, rgba(52,138,132,0.06), rgba(52,138,132,0.06));
  transform: scale(1.02);
}
.review-card--featured:hover { transform: scale(1.02) translateY(-5px); }

.review-card__badge {
  position: absolute;
  top: -12px;
  left: 28px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(135deg, var(--accent), var(--accent-purple));
  padding: 4px 12px;
  border-radius: var(--radius-full);
}

.review-card__stars {
  display: flex;
  gap: 2px;
  margin-bottom: 16px;
}
.review-card__stars svg { width: 16px; height: 16px; }

.review-card__quote {
  font-size: 0.9375rem;
  color: var(--text-secondary);
  line-height: 1.7;
  font-style: italic;
  margin-bottom: 24px;
  border: none;
}

.review-card__author {
  display: flex;
  align-items: center;
  gap: 12px;
}
.review-card__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  flex-shrink: 0;
}
.review-card__avatar--1 { background: linear-gradient(135deg, var(--accent-light), var(--accent)); color: #fff; }
.review-card__avatar--2 { background: linear-gradient(135deg, var(--accent-light), var(--accent-dark)); color: #fff; }
.review-card__avatar--3 { background: linear-gradient(135deg, #10B981, var(--accent-light)); color: #fff; }

.review-card__name { font-size: 0.9rem; font-weight: 600; color: var(--text-primary); }
.review-card__role { font-size: 0.8rem; color: var(--text-tertiary); }

/* ===================== SOCIAL SECTION ===================== */
.social {
  padding: clamp(80px, 10vw, 140px) 0;
}

.social__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.social-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  overflow: hidden;
  transition: transform var(--t-normal) var(--ease-spring), border-color var(--t-normal), box-shadow var(--t-normal);
}
.social-card:hover { transform: translateY(-5px) scale(1.02); }

/* Animated gradient background */
.social-card__glow {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity var(--t-slow);
  border-radius: inherit;
}
.social-card:hover .social-card__glow { opacity: 1; }

/* Per-platform colors */
.social-card--instagram { --sc: #E1306C; --sc2: #F77737; }
.social-card--twitter   { --sc: #1DA1F2; --sc2: #0D8ECF; }
.social-card--linkedin  { --sc: #0A66C2; --sc2: #004182; }
.social-card--youtube   { --sc: #FF0000; --sc2: #CC0000; }

.social-card__glow {
  background: radial-gradient(ellipse at top left, color-mix(in srgb, var(--sc) 20%, transparent), transparent 60%);
}

.social-card:hover {
  border-color: color-mix(in srgb, var(--sc) 40%, transparent);
  box-shadow: 0 0 30px color-mix(in srgb, var(--sc) 15%, transparent);
}

.social-card__icon {
  width: 44px;
  height: 44px;
  background: color-mix(in srgb, var(--sc) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--sc) 25%, transparent);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--sc);
  transition: background var(--t-normal), box-shadow var(--t-normal);
}
.social-card__icon svg { width: 22px; height: 22px; }
.social-card:hover .social-card__icon {
  background: color-mix(in srgb, var(--sc) 20%, transparent);
  box-shadow: 0 0 16px color-mix(in srgb, var(--sc) 30%, transparent);
}

.social-card__name {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-top: 4px;
}
.social-card__handle { font-size: 0.8125rem; color: var(--text-tertiary); }

.social-card__arrow {
  margin-top: auto;
  color: var(--text-tertiary);
  transition: color var(--t-fast), transform var(--t-fast);
}
.social-card:hover .social-card__arrow {
  color: var(--sc);
  transform: translate(2px, -2px);
}

/* ===================== CONTACT SECTION ===================== */
.contact {
  padding: clamp(80px, 10vw, 140px) 0;
}

.contact__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: start;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: clamp(32px, 5vw, 64px);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.contact__left .section-title { margin-bottom: 16px; }
.contact__left .section-subtitle { margin-bottom: 32px; }
.contact__left .section-badge { margin-bottom: 20px; }

.contact__info { display: flex; flex-direction: column; gap: 14px; }
.contact__info-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.9rem;
  color: var(--text-secondary);
}
.contact__info-item svg { color: var(--accent); flex-shrink: 0; }

/* Forms */
.contact__form { display: flex; flex-direction: column; gap: 20px; }

.form-group { display: flex; flex-direction: column; gap: 8px; }

.form-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: 0.01em;
}

.form-input,
.form-textarea {
  width: 100%;
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: var(--radius-md);
  padding: 13px 16px;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  color: var(--text-primary);
  transition: border-color var(--t-normal), box-shadow var(--t-normal), background var(--t-normal);
  resize: none;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

.form-input::placeholder,
.form-textarea::placeholder { color: var(--text-tertiary); }

.form-input:focus,
.form-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(52,138,132,0.12), 0 0 20px rgba(52,138,132,0.08);
  background: color-mix(in srgb, var(--input-bg) 80%, rgba(52,138,132,0.05) 20%);
}

.form-textarea { min-height: 130px; line-height: 1.6; }

.form-success {
  display: none;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: rgba(16,185,129,0.1);
  border: 1px solid rgba(16,185,129,0.25);
  border-radius: var(--radius-md);
  color: var(--accent-emerald);
  font-size: 0.9rem;
  font-weight: 500;
}
.form-success.visible { display: flex; }

.form-error {
  display: none;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: rgba(239,68,68,0.08);
  border: 1px solid rgba(239,68,68,0.25);
  border-radius: var(--radius-md);
  color: #f87171;
  font-size: 0.9rem;
  font-weight: 500;
}
.form-error.visible { display: flex; }

/* Field-level validation feedback */
.form-input.input--error,
.form-textarea.input--error {
  border-color: #f87171 !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,0.12) !important;
}
.form-field-error {
  display: none;
  font-size: 0.8rem;
  color: #f87171;
  margin-top: 4px;
  padding-left: 2px;
}
.form-field-error.visible { display: block; }

/* ===================== DOWNLOAD CTA ===================== */
.download-cta {
  position: relative;
  padding: clamp(80px, 10vw, 140px) 0;
  overflow: hidden;
}
.download-cta__orbs { position: absolute; inset: 0; pointer-events: none; }
.orb--dl-1 {
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(52,138,132,0.2) 0%, transparent 70%);
  top: 50%; left: 20%;
  transform: translate(-50%, -50%);
  animation: orbFloat 12s ease-in-out infinite alternate;
}
.orb--dl-2 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(52,138,132,0.15) 0%, transparent 70%);
  top: 50%; right: 10%;
  transform: translate(0, -50%);
  animation: orbFloat 10s ease-in-out infinite alternate-reverse;
}

.download-cta__content {
  position: relative;
  z-index: 1;
  text-align: center;
}
.download-cta__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--text-primary);
  margin-bottom: 16px;
}
.download-cta__subtitle {
  font-size: clamp(1rem, 2vw, 1.125rem);
  color: var(--text-secondary);
  max-width: 480px;
  margin: 0 auto 36px;
}
.download-cta__btns { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
.download-cta__note { margin-top: 20px; font-size: 0.8125rem; color: var(--text-tertiary); }

/* ===================== FOOTER ===================== */
.footer {
  border-top: 1px solid var(--surface-border);
  padding: clamp(40px, 6vw, 64px) 0 32px;
}

.footer__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 32px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.footer__brand .nav__logo { margin-bottom: 8px; }
.footer__tagline { font-size: 0.875rem; color: var(--text-tertiary); margin-top: 8px; }

.footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 4px;
  align-items: center;
}
.footer__link {
  font-size: 0.875rem;
  color: var(--text-secondary);
  padding: 6px 12px;
  border-radius: var(--radius-full);
  transition: color var(--t-fast), background var(--t-fast);
}
.footer__link:hover {
  color: var(--text-primary);
  background: var(--surface);
}

.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 24px;
  border-top: 1px solid var(--surface-border);
}
.footer__copy, .footer__made {
  font-size: 0.8125rem;
  color: var(--text-tertiary);
}

/* ===================== RESPONSIVE ===================== */

/* Tablet */
@media (max-width: 1024px) {
  .reviews__grid { grid-template-columns: 1fr; gap: 16px; }
  .review-card--featured { transform: none; }
  .review-card--featured:hover { transform: translateY(-5px); }

  .social__grid { grid-template-columns: repeat(2, 1fr); }

  .mockups__track { justify-content: flex-start; }
}

@media (max-width: 900px) {
  .hero__container {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .hero__content { max-width: 100%; }
  .hero__subtitle { max-width: 100%; }
  .hero__cta { justify-content: center; }
  .hero__stats { justify-content: center; }
  .hero__mockup { display: none; }

  .contact__inner { grid-template-columns: 1fr; }

  .nav__links { display: none; }
  .nav__hamburger { display: flex; }
  .nav__actions .btn--sm { display: none; }
}

@media (max-width: 640px) {
  .features__grid { grid-template-columns: 1fr; }
  .social__grid   { grid-template-columns: 1fr; }

  .footer__top    { flex-direction: column; }
  .footer__bottom { flex-direction: column; text-align: center; }

  .mockups__track { padding-inline: 20px; }

  .hero__stats { flex-direction: column; gap: 16px; }
  .hero__stat-divider { width: 48px; height: 1px; }
  .hero__stat { padding: 0; }
}

/* Light mode phone */
[data-theme="light"] .app-screen,
[data-theme="light"] .app-screen--focus,
[data-theme="light"] .app-screen--capture,
[data-theme="light"] .app-screen--plan,
[data-theme="light"] .app-screen--review,
[data-theme="light"] .app-screen--settings {
  background: linear-gradient(180deg, #1e1b4b 0%, #0f0c29 100%);
}

/* ===================== ACCESSIBILITY ===================== */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
}

/* Focus visible */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ===================== MOCKUPS — 3-UP LAYOUT ===================== */
/* Mobile-first: single full-width item; tablet -> 2-up; desktop -> 3-up */
.mockup-item { width: 92%; }

@media (min-width: 700px) {
  .mockup-item { flex: 0 0 calc((100% - 32px) / 2); max-width: 520px; }
  .mockups__track { justify-content: flex-start; overflow: hidden; }
}

@media (min-width: 1000px) {
  .mockup-item { flex: 0 0 calc((100% - 64px) / 3); max-width: 420px; }
  .mockups__track { padding-inline: clamp(24px, 5vw, 120px); }
}

/* Small polish: ensure mockup images scale and stay crisp */
.mockup-item .phone-mockup__frame { transform-origin: center; }


/* ============================================================
   DESIGN POLISH — Startup-grade finishing layer
   ============================================================ */

/* ------ 1. HERO GRAIN -------
   Subtle noise texture gives the hero depth and high-end feel */
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
  opacity: 0.7;
  border-radius: 0;
}

/* ------ 2. SECTION DIVIDERS ------
   Ultra-slim gradient lines that bleed entirely across the viewport */
.features,
.mockups,
.mockups--pro,
.reviews,
.contact,
.download-cta {
  position: relative;
}
.features::before,
.mockups::before,
.reviews::before,
.contact::before,
.download-cta::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(52,138,132,0.18) 20%,
    rgba(52,138,132,0.35) 50%,
    rgba(52,138,132,0.18) 80%,
    transparent 100%
  );
}

/* ------ 3. SECTION HEADER refinements ------ */
.section-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.section-badge::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
  flex-shrink: 0;
}
.section-header {
  position: relative;
}
/* Thin underline accent for section titles */
.section-header .section-title::after {
  content: '';
  display: block;
  width: 40px;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent);
  border-radius: 2px;
  margin: 14px auto 0;
}

/* ------ 4. HERO BADGE polish ------ */
.hero__badge {
  border: 1px solid rgba(52,138,132,0.25);
  background: linear-gradient(135deg, rgba(52,138,132,0.08), rgba(52,138,132,0.04));
  backdrop-filter: blur(8px);
}

/* ------ 5. HERO STAT bar refinement ------ */
.hero__stats {
  background: var(--surface);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-lg);
  padding: 14px 24px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: inline-flex;
  align-self: flex-start;
}
.hero__stat { padding: 0 24px; }
.hero__stat:first-child { padding-left: 0; }

/* ------ 6. FEATURE CARD top-glow bar ------ */
.feature-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(52,138,132,0.12), transparent);
}
/* Make feature-card icon bigger, icon wrap more prominent */
.feature-card__icon-wrap {
  width: 60px;
  height: 60px;
}
.feature-card__icon { width: 36px; height: 36px; }
.feature-card__title { font-size: 1.1875rem; }
/* Number badge accent on feature cards (corner spark) */
.feature-card:nth-child(1)::before { background: linear-gradient(90deg, transparent, rgba(52,138,132,0.6), transparent); }
.feature-card:nth-child(2)::before { background: linear-gradient(90deg, transparent, rgba(102,189,185,0.6), transparent); }
.feature-card:nth-child(3)::before { background: linear-gradient(90deg, transparent, rgba(16,185,129,0.6), transparent); }
.feature-card:nth-child(4)::before { background: linear-gradient(90deg, transparent, rgba(245,158,11,0.6), transparent); }

/* ------ 7. DOWNLOAD CTA — glass card container ------ */
.download-cta .container {
  position: relative;
  z-index: 1;
}
.download-cta__content {
  background: linear-gradient(
    145deg,
    rgba(52,138,132,0.07) 0%,
    rgba(255,255,255,0.025) 100%
  );
  border: 1px solid rgba(52,138,132,0.18);
  border-radius: var(--radius-xl);
  padding: clamp(48px, 7vw, 96px) clamp(32px, 6vw, 80px);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  position: relative;
  overflow: hidden;
}
/* Corner glow sparks */
.download-cta__content::before {
  content: '';
  position: absolute;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(52,138,132,0.18) 0%, transparent 70%);
  top: -80px;
  left: -60px;
  border-radius: 50%;
  pointer-events: none;
}
.download-cta__content::after {
  content: '';
  position: absolute;
  width: 250px;
  height: 250px;
  background: radial-gradient(circle, rgba(52,138,132,0.12) 0%, transparent 70%);
  bottom: -60px;
  right: -40px;
  border-radius: 50%;
  pointer-events: none;
}

/* ------ 8. REVIEW CARDS refinements ------ */
.reviews__grid {
  grid-template-columns: repeat(3, 1fr);
}
.review-card {
  border-radius: var(--radius-xl);
  padding: 36px 32px;
}
.review-card--featured {
  background: linear-gradient(
    145deg,
    rgba(52,138,132,0.08) 0%,
    rgba(255,255,255,0.025) 100%
  );
  border-color: rgba(52,138,132,0.28);
}
/* Left quote decoration */
.review-card__quote::before {
  content: '"';
  font-family: var(--font-display);
  font-size: 5rem;
  font-weight: 900;
  line-height: 0.5;
  color: rgba(52,138,132,0.15);
  display: block;
  margin-bottom: 16px;
  letter-spacing: -0.04em;
}

/* ------ 9. NAV LOGO text shimmer ------ */
.nav__logo-text {
  background: linear-gradient(135deg, var(--text-primary) 60%, var(--accent-light) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ------ 10. NAV scroll border extra glow ------ */
.nav.scrolled {
  box-shadow: 0 1px 0 rgba(52,138,132,0.12), 0 4px 40px rgba(0,0,0,0.3);
}

/* ------ 11. MOCKUPS section decorative grid background ------ */
#mockups {
  background: radial-gradient(ellipse 90% 60% at 50% 80%, rgba(52,138,132,0.04) 0%, transparent 70%);
}

/* ------ 12. PRO section background strip ------ */
.mockups--pro {
  background: linear-gradient(180deg, transparent 0%, rgba(52,138,132,0.025) 50%, transparent 100%);
}

/* ------ 13. FOOTER refinements ------ */
.footer {
  position: relative;
}
.footer::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(52,138,132,0.25) 30%,
    rgba(52,138,132,0.45) 50%,
    rgba(52,138,132,0.25) 70%,
    transparent 100%
  );
}
.footer__copy, .footer__made {
  font-size: 0.8125rem;
  color: var(--text-tertiary);
  letter-spacing: 0.01em;
}

/* ------ 14. CONTACT section inner card refinements ------ */
.contact__inner {
  background: linear-gradient(
    145deg,
    rgba(255,255,255,0.035) 0%,
    rgba(52,138,132,0.04) 100%
  );
  border-color: rgba(52,138,132,0.12);
  border-radius: var(--radius-xl);
  position: relative;
  overflow: hidden;
}
.contact__inner::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(52,138,132,0.4), rgba(255,255,255,0.08), transparent);
  pointer-events: none;
}

/* ------ 15. BTN primary – mouse-tracked shimmer ------ */
.btn--primary::before {
  background: radial-gradient(
    circle at var(--mx, 50%) var(--my, 50%),
    rgba(255,255,255,0.22) 0%,
    transparent 65%
  );
}

/* ------ 16. SCROLLBAR accent ------ */
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--accent-light), var(--accent));
}

/* ------ 17. Responsive patches for polish layer ------ */
@media (max-width: 1024px) {
  .reviews__grid { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .hero__stats { align-self: center; }
}
@media (max-width: 640px) {
  .download-cta__content { padding: 36px 24px; }
  .review-card { padding: 28px 22px; }
}

/* ============================================================
   PRO FEATURES GRID
   ============================================================ */
.pro-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 72px;
}

.pro-feature-item {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 24px 22px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: transform var(--t-normal) var(--ease-spring),
              border-color var(--t-normal),
              box-shadow var(--t-normal);
  position: relative;
  overflow: hidden;
}

/* top-edge glow on hover */
.pro-feature-item::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(52,138,132,0.55), transparent);
  opacity: 0;
  transition: opacity var(--t-normal);
}
.pro-feature-item:hover { transform: translateY(-4px); }
.pro-feature-item:hover::before { opacity: 1; }
.pro-feature-item:hover {
  border-color: rgba(52,138,132,0.22);
  box-shadow: 0 16px 48px rgba(52,138,132,0.08);
}

.pro-feature-item__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  background: rgba(52,138,132,0.1);
  border: 1px solid rgba(52,138,132,0.18);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-light);
  transition: background var(--t-normal), box-shadow var(--t-normal);
}
.pro-feature-item:hover .pro-feature-item__icon {
  background: rgba(52,138,132,0.18);
  box-shadow: 0 0 16px rgba(52,138,132,0.25);
}

.pro-feature-item__title {
  font-family: var(--font-display);
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  margin-bottom: 5px;
}
.pro-feature-item__desc {
  font-size: 0.8375rem;
  color: var(--text-secondary);
  line-height: 1.6;
}

/* Responsive */
@media (max-width: 900px) {
  .pro-features { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .pro-features { grid-template-columns: 1fr; }
}

/* ============================================================
   HULORA STUDIO SECTION
   ============================================================ */
.studio {
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
}

/* separator above */
.studio::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(52,138,132,0.18) 20%,
    rgba(52,138,132,0.35) 50%,
    rgba(52,138,132,0.18) 80%,
    transparent 100%
  );
}

/* Background accent */
.studio::after {
  content: '';
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 700px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(52,138,132,0.05) 0%, transparent 70%);
  pointer-events: none;
}

.studio__inner {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: clamp(48px, 7vw, 100px);
  align-items: start;
  position: relative;
  z-index: 1;
}

/* ---- Brand column ---- */
.studio__logo-wrap {
  width: 72px;
  height: 72px;
  background: rgba(52,138,132,0.08);
  border: 1px solid rgba(52,138,132,0.18);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  box-shadow: 0 0 24px rgba(52,138,132,0.12);
}
.studio__logo {
  width: 48px;
  height: 48px;
  object-fit: contain;
}

.studio__name {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--text-primary);
  margin-bottom: 12px;
  line-height: 1.1;
}

.studio__badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-light);
  background: rgba(52,138,132,0.1);
  border: 1px solid rgba(52,138,132,0.2);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  margin-bottom: 24px;
}
.studio__badge::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 5px var(--accent);
  animation: pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}

.studio__desc {
  font-size: clamp(0.9375rem, 1.8vw, 1.0625rem);
  color: var(--text-secondary);
  line-height: 1.75;
  max-width: 460px;
  margin-bottom: 32px;
}

.studio__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.studio__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--text-tertiary);
  background: var(--surface);
  border: 1px solid var(--surface-border);
  padding: 5px 12px;
  border-radius: var(--radius-full);
}
.studio__meta-item svg { color: var(--accent); flex-shrink: 0; }

/* ---- Socials column ---- */
.studio__socials-title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}
.studio__socials-sub {
  font-size: 0.9rem;
  color: var(--text-secondary);
  margin-bottom: 28px;
  line-height: 1.6;
}

.studio__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

/* Studio social card */
.studio-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  overflow: hidden;
  text-decoration: none;
  transition: transform var(--t-normal) var(--ease-spring),
              border-color var(--t-normal),
              box-shadow var(--t-normal);
}

/* Platform colour tokens */
.studio-card--instagram { --sc: #E1306C; --sc2: #F77737; }
.studio-card--tiktok    { --sc: #010101; --sc2: #69C9D0; }
.studio-card--twitter   { --sc: #1A1A1A; --sc2: #e7e7e7; }
.studio-card--website   { --sc: #348a84; --sc2: #216f6c; }
.studio-card--youtube   { --sc: #FF0000; --sc2: #CC0000; }
.studio-card--email     { --sc: var(--accent); --sc2: var(--accent-dark); }

.studio-card__glow {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top left, color-mix(in srgb, var(--sc) 18%, transparent), transparent 65%);
  opacity: 0;
  transition: opacity var(--t-slow);
  pointer-events: none;
}

.studio-card:hover {
  transform: translateY(-4px) scale(1.02);
  border-color: color-mix(in srgb, var(--sc) 40%, transparent);
  box-shadow: 0 0 28px color-mix(in srgb, var(--sc) 14%, transparent);
}
.studio-card:hover .studio-card__glow { opacity: 1; }

.studio-card__icon {
  flex-shrink: 0;
  width: 42px;
  height: 42px;
  background: color-mix(in srgb, var(--sc) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--sc) 25%, transparent);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: color-mix(in srgb, var(--sc) 90%, white 10%);
  position: relative;
  z-index: 1;
  transition: background var(--t-normal), box-shadow var(--t-normal);
}
.studio-card--tiktok .studio-card__icon { color: #69C9D0; }
.studio-card--twitter .studio-card__icon { color: var(--text-primary); }
.studio-card:hover .studio-card__icon {
  background: color-mix(in srgb, var(--sc) 20%, transparent);
  box-shadow: 0 0 14px color-mix(in srgb, var(--sc) 28%, transparent);
}

.studio-card__info {
  flex: 1;
  min-width: 0;
  position: relative;
  z-index: 1;
}
.studio-card__name {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
}
.studio-card__handle {
  font-size: 0.79rem;
  color: var(--text-tertiary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.studio-card__arrow {
  color: var(--text-tertiary);
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  transition: color var(--t-fast), transform var(--t-fast);
}
.studio-card:hover .studio-card__arrow {
  color: color-mix(in srgb, var(--sc) 80%, white 20%);
  transform: translate(3px, -3px);
}

/* Responsive */
@media (max-width: 960px) {
  .studio__inner { grid-template-columns: 1fr; gap: 48px; }
  .studio__desc { max-width: 100%; }
}
@media (max-width: 560px) {
  .studio__grid { grid-template-columns: 1fr; }
}

/* =========================================================
   STUDIO LOGO — larger, polished SVG styling
   ========================================================= */
.studio__logo-wrap {
  width: 220px;
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  padding: 18px;
  box-shadow: 0 18px 45px rgba(168,85,247,0.08), 0 6px 18px rgba(0,0,0,0.35);
  transition: transform var(--t-fast), box-shadow var(--t-fast);
  margin-bottom: 1rem;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.04);
  z-index: 2;
}
.studio__logo {
  width: 100%;
  max-width: 190px;
  height: auto;
  display: block;
  filter: drop-shadow(0 10px 30px rgba(168,85,247,0.12)) drop-shadow(0 4px 12px rgba(52,138,132,0.06));
  transition: transform var(--t-fast), filter var(--t-fast);
}
.studio__logo-wrap:hover { transform: translateY(-6px) scale(1.01); box-shadow: 0 26px 60px rgba(168,85,247,0.11), 0 8px 22px rgba(0,0,0,0.42); }
.studio__logo-wrap:hover .studio__logo { transform: translateY(-4px); }

@media (max-width: 960px) {
  .studio__logo-wrap { width: 160px; height: 160px; padding: 14px; }
  .studio__logo { max-width: 140px; }
}
@media (max-width: 560px) {
  .studio__logo-wrap { width: 120px; height: 120px; padding: 10px; }
  .studio__logo { max-width: 100px; }
}

/* =========================================================
   VALUE / PROBLEM SECTION
   ========================================================= */
.value {
  padding: var(--section-pad) 0;
  position: relative;
  overflow: hidden;
}
.value::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 50% at 50% 100%, rgba(52,138,132,0.07) 0%, transparent 70%);
  pointer-events: none;
}

.value__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
}

.value-card {
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 1.25rem;
  padding: 2rem 1.5rem;
  transition: border-color 0.3s, transform 0.3s, box-shadow 0.3s;
}
.value-card:hover {
  border-color: rgba(52,138,132,0.4);
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(52,138,132,0.1);
}

.value-card__icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(52,138,132,0.2), rgba(52,138,132,0.05));
  border: 1px solid rgba(52,138,132,0.3);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  margin-bottom: 1.25rem;
}

/* Per-card icon theming — distinct color per problem */
.value__grid .value-card:nth-child(1) .value-card__icon {
  color: #8b5cf6;
  background: linear-gradient(135deg, rgba(139,92,246,0.18), rgba(139,92,246,0.05));
  border-color: rgba(139,92,246,0.28);
  box-shadow: 0 0 18px rgba(139,92,246,0.12);
}
.value__grid .value-card:nth-child(2) .value-card__icon {
  color: #f59e0b;
  background: linear-gradient(135deg, rgba(245,158,11,0.18), rgba(245,158,11,0.05));
  border-color: rgba(245,158,11,0.28);
  box-shadow: 0 0 18px rgba(245,158,11,0.12);
}
.value__grid .value-card:nth-child(3) .value-card__icon {
  color: #94a3b8;
  background: linear-gradient(135deg, rgba(100,116,139,0.18), rgba(100,116,139,0.05));
  border-color: rgba(100,116,139,0.28);
  box-shadow: 0 0 18px rgba(100,116,139,0.08);
}

.value-card__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary, #f0f0f0);
  margin: 0 0 0.5rem;
  font-family: 'Space Grotesk', sans-serif;
}

.value-card__desc {
  font-size: 0.9rem;
  color: var(--text-secondary, rgba(255,255,255,0.5));
  line-height: 1.65;
  margin: 0;
}

.value__cta {
  margin-top: 3rem;
  text-align: center;
  padding: 2.25rem 2rem;
  background: linear-gradient(135deg, rgba(52,138,132,0.09), rgba(52,138,132,0.03));
  border: 1px solid rgba(52,138,132,0.22);
  border-radius: 1.25rem;
  position: relative;
  overflow: hidden;
}
.value__cta::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

.value__cta-text {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--text-primary, #f0f0f0);
  margin: 0 0 0.4rem;
  font-family: 'Space Grotesk', sans-serif;
}

.value__cta-sub {
  font-size: 0.92rem;
  color: var(--text-secondary, rgba(255,255,255,0.5));
  margin: 0;
}
.value__cta-sub em {
  font-style: normal;
  color: var(--accent);
  font-weight: 600;
}

@media (max-width: 860px) {
  .value__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .value__grid { grid-template-columns: 1fr; gap: 1rem; }
}

/* =========================================================
   PRO SECTION — PREMIUM UPGRADE
   ========================================================= */

/* Animated aurora background */
.mockups--pro {
  position: relative;
  background:
    radial-gradient(ellipse 90% 55% at 50% 20%, rgba(52,138,132,0.18) 0%, transparent 65%),
    radial-gradient(ellipse 60% 50% at 15% 85%, rgba(168,85,247,0.14) 0%, transparent 60%),
    radial-gradient(ellipse 55% 45% at 85% 70%, rgba(52,138,132,0.10) 0%, transparent 55%),
    var(--bg);
  overflow: hidden;
}

/* Moving aurora sweep */
@keyframes proAurora {
  0%   { transform: scale(1.0) translateX(-6%) translateY(2%);  opacity: 0.55; }
  45%  { transform: scale(1.12) translateX(6%)  translateY(-3%); opacity: 1; }
  100% { transform: scale(0.97) translateX(-4%) translateY(4%);  opacity: 0.65; }
}

.mockups--pro::before {
  content: '';
  position: absolute;
  inset: -20%;
  background: radial-gradient(ellipse 70% 60% at 50% 45%,
    rgba(168,85,247,0.13) 0%,
    rgba(52,138,132,0.10) 40%,
    transparent 70%);
  animation: proAurora 9s ease-in-out infinite alternate;
  pointer-events: none;
  z-index: 0;
}

/* Flowing top border */
@keyframes proBorderFlow {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.mockups--pro::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--accent) 25%,
    #a855f7 50%,
    var(--accent) 75%,
    transparent 100%);
  background-size: 200% 100%;
  animation: proBorderFlow 4.5s linear infinite;
  z-index: 1;
}

/* Keep interior above bg */
.mockups--pro .container,
.mockups--pro .mockups__carousel {
  position: relative;
  z-index: 1;
}

/* Premium section badge */
.mockups--pro .section-badge {
  background: linear-gradient(135deg, rgba(168,85,247,0.22), rgba(52,138,132,0.18));
  border-color: rgba(168,85,247,0.45);
  color: #c084fc;
  box-shadow: 0 0 24px rgba(168,85,247,0.22), 0 0 8px rgba(168,85,247,0.12);
}

/* Gradient section title */
.mockups--pro .section-title {
  background: linear-gradient(135deg, #ffffff 20%, #7dd8d4 55%, #c084fc 90%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Stronger & purple-tinted phone glow */
.mockups--pro .phone-mockup__glow {
  background: radial-gradient(ellipse,
    rgba(168,85,247,0.38) 0%,
    rgba(52,138,132,0.28) 40%,
    transparent 70%);
  width: 140%;
  height: 140%;
  top: -20%;
  left: -20%;
}

/* Pro feature cards — purple accent */
.pro-feature-item {
  background: linear-gradient(135deg, rgba(255,255,255,0.035) 0%, rgba(168,85,247,0.045) 100%) !important;
  border-color: rgba(168,85,247,0.14) !important;
}
.pro-feature-item:hover {
  border-color: rgba(168,85,247,0.42) !important;
  box-shadow: 0 8px 36px rgba(168,85,247,0.14), 0 0 0 1px rgba(52,138,132,0.08) !important;
}
.pro-feature-item__icon {
  color: #c084fc !important;
  background: linear-gradient(135deg, rgba(168,85,247,0.18), rgba(52,138,132,0.08)) !important;
  border-color: rgba(168,85,247,0.28) !important;
}
.pro-feature-item:hover .pro-feature-item__icon {
  background: rgba(168,85,247,0.24) !important;
  box-shadow: 0 0 18px rgba(168,85,247,0.28) !important;
  border-color: rgba(168,85,247,0.45) !important;
}

/* Subtle star-field particles via box-shadow */
@keyframes proFloat {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-8px); }
}
.mockups--pro .mockup-item {
  animation: proFloat 6s ease-in-out infinite;
}
.mockups--pro .mockup-item:nth-child(2) { animation-delay: 0.8s; }
.mockups--pro .mockup-item:nth-child(3) { animation-delay: 1.6s; }
.mockups--pro .mockup-item:nth-child(4) { animation-delay: 0.4s; }
.mockups--pro .mockup-item:nth-child(5) { animation-delay: 1.2s; }
.mockups--pro .mockup-item:nth-child(6) { animation-delay: 2.0s; }

/* ============================================================
   MASTER RESPONSIVE SYSTEM
   Single source of truth — all breakpoints, no conflicts.
   Placed last → always wins the cascade.
   ============================================================ */

/* 0. Global overflow guard */
body { overflow-x: hidden; }
.container, .hero__container, .nav__container { max-width: min(1200px, 100%); }

/* 1. Hero mockup — smooth transition before hard hide */
.hero__mockup {
  transition: opacity 0.4s var(--ease-out), transform 0.4s var(--ease-out);
}

/* ════════════════════════════════════════════════════════════
   ≤ 1100px  — slightly shrink hero phone
   ════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .hero__container         { gap: clamp(24px, 4vw, 48px); }
  .phone-mockup--hero .phone-mockup__frame {
    width: 240px;
    height: 480px;
  }

  /* #mockups — proportionally smaller phones */
  #mockups .mockups__grid  { gap: 24px; padding-inline: 24px; }
  #mockups .mockups__grid .phone-mockup--sm .phone-mockup__frame {
    width: 240px;
    height: 480px;
    border-radius: 40px;
  }
  #mockups .mockups__grid .phone-mockup--sm .phone-mockup__screen { border-radius: 30px; }
}

/* ════════════════════════════════════════════════════════════
   ≤ 960px  — reviews 1-col, studio stack
   ════════════════════════════════════════════════════════════ */
@media (max-width: 960px) {
  .reviews__grid { grid-template-columns: 1fr; gap: 16px; }
  .review-card--featured  { transform: none; }
  .review-card--featured:hover { transform: translateY(-5px); }

  .studio__inner { grid-template-columns: 1fr; gap: 48px; }
  .studio__desc  { max-width: 100%; }
  /* keep studio social grid 2-col until very small */
  .studio__grid  { grid-template-columns: repeat(2, 1fr); }
}

/* ════════════════════════════════════════════════════════════
   ≤ 900px  — hero single-col, hide phone mockup, nav hamburger
   ════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  /* ── Hero ── */
  .hero__container {
    grid-template-columns: 1fr;
    text-align: center;
    padding-top: calc(var(--nav-h) + 32px);
    padding-bottom: 56px;
  }
  .hero__content    { max-width: 100%; }
  .hero__subtitle   { max-width: 100%; margin-inline: auto; }
  .hero__cta        { justify-content: center; flex-wrap: wrap; }
  .hero__stats      { justify-content: center; align-self: center; }
  .hero__mockup     { display: none; }     /* hidden — content is full-width stead */

  /* ── Nav ── */
  .nav__links               { display: none; }
  .nav__hamburger           { display: flex; }
  .nav__actions .btn--sm    { display: none; }

  /* ── Contact ── */
  .contact__inner { grid-template-columns: 1fr; }

  /* ── Value / Problem (3 cards) — 2-col until 600 px ── */
  .value__grid {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }
  /* 3rd card full-width row, auto width */
  .value__grid .value-card:nth-child(3) {
    grid-column: 1 / -1;
    width: calc(50% - 0.5rem);
    margin-inline: auto;
  }

  /* ── Features (4 cards) — 2×2 ── */
  .features__grid { grid-template-columns: 1fr 1fr; gap: 16px; }

  /* ── Pro features — 2-col ── */
  .pro-features { grid-template-columns: repeat(2, 1fr); }

  /* ── #mockups 3 phones — reduce size ── */
  #mockups .mockups__grid {
    gap: 16px;
    padding-inline: 16px;
  }
  #mockups .mockups__grid .phone-mockup--sm .phone-mockup__frame {
    width: 190px;
    height: 380px;
    border-radius: 34px;
    padding: 11px 9px;
  }
  #mockups .mockups__grid .phone-mockup--sm .phone-mockup__screen { border-radius: 24px; }
}

/* ════════════════════════════════════════════════════════════
   ≤ 720px  — #mockups phones stack vertically
   ════════════════════════════════════════════════════════════ */
@media (max-width: 720px) {
  #mockups .mockups__grid {
    flex-direction: column;
    align-items: center;
    flex-wrap: nowrap;
    gap: 28px;
    padding: 20px 16px;
  }
  #mockups .mockups__grid .mockup-item {
    flex: none;
    width: 100%;
    max-width: 280px;
  }
  /* reset intermediate size rules */
  #mockups .mockups__grid .phone-mockup--sm .phone-mockup__frame {
    width: min(240px, 60vw);
    height: min(480px, 120vw);
    border-radius: 40px;
    padding: 12px 10px;
  }
  #mockups .mockups__grid .phone-mockup--sm .phone-mockup__screen { border-radius: 30px; }
}

/* ════════════════════════════════════════════════════════════
   Pro carousel — items-per-view via explicit flex widths
   JS calcLayout() reads offsetWidth and auto-computes pages.
   ════════════════════════════════════════════════════════════ */

/* Base (mobile < 600 px): 1 per view */
.mockups--pro .mockup-item {
  flex: 0 0 min(260px, calc(100vw - 48px));
  max-width: 260px;
}
/* ≥ 600px: 2 per view */
@media (min-width: 600px) {
  .mockups--pro .mockup-item {
    flex: 0 0 calc(50% - 30px);
    max-width: 280px;
  }
}
/* ≥ 860px: 3 per view */
@media (min-width: 860px) {
  .mockups--pro .mockup-item {
    flex: 0 0 calc(33.333% - 28px);
    max-width: 260px;
  }
}
/* ≥ 1100px: 4 per view */
@media (min-width: 1100px) {
  .mockups--pro .mockup-item {
    flex: 0 0 calc(25% - 24px);
    max-width: 240px;
  }
}

/* Ensure pro track scrolls correctly */
.mockups--pro .mockups__track {
  overflow: hidden;
  justify-content: flex-start;
  gap: 24px;
  padding-inline: clamp(16px, 4vw, 48px);
}

/* ════════════════════════════════════════════════════════════
   ≤ 600px  — inverted-pyramid for Value cards, features 2-col
   ════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
  /* Value section: 2nd card floats to top row (inverted pyramid)
     Card order: 2 (top, centered) → 1 (bottom-left) → 3 (bottom-right) */
  .value__grid {
    grid-template-columns: 1fr 1fr;
    gap: 0.875rem;
  }
  .value__grid .value-card:nth-child(2) {
    order: -1;                       /* pull to top */
    grid-column: 1 / -1;             /* span full width */
    max-width: calc(50% - 0.44rem);  /* only half-wide, like the cards below */
    margin-inline: auto;
    width: 100%;
  }
  .value__grid .value-card:nth-child(1) { order: 0; }
  .value__grid .value-card:nth-child(3) { order: 0; }

  /* Features: 2 per row */
  .features__grid { grid-template-columns: 1fr 1fr; gap: 12px; }

  /* Pro features: 1-col */
  .pro-features { grid-template-columns: 1fr; }

  /* Studio socials: 1-col */
  .studio__grid { grid-template-columns: 1fr; }

  /* Stats: vertical stack */
  .hero__stats {
    flex-direction: column;
    gap: 16px;
    align-self: center;
  }
  .hero__stat-divider { width: 48px; height: 1px; }
  .hero__stat { padding: 0; }

  /* Footer */
  .footer__top    { flex-direction: column; }
  .footer__bottom { flex-direction: column; text-align: center; }

  /* Orbs — cap to viewport width */
  .orb--1 { width: min(420px, 120vw); height: min(420px, 120vw); }
  .orb--2 { width: min(340px, 100vw); height: min(340px, 100vw); }
  .orb--3 { width: min(260px,  80vw); height: min(260px,  80vw); }
}

/* ════════════════════════════════════════════════════════════
   ≤ 420px  — very small phones, fall back to 1-col everywhere
   ════════════════════════════════════════════════════════════ */
@media (max-width: 420px) {
  /* Value: full single column */
  .value__grid { grid-template-columns: 1fr; gap: 0.75rem; }
  .value__grid .value-card:nth-child(2) {
    order: 0;
    grid-column: auto;
    max-width: 100%;
    margin-inline: 0;
  }

  /* Features: 1-col */
  .features__grid { grid-template-columns: 1fr; }

  /* Hero CTA: stacked buttons */
  .hero__cta { flex-direction: column; align-items: stretch; }
  .hero__cta .btn { justify-content: center; }

  /* Nav logo: hide text */
  .nav__logo-text { display: none; }
  .nav__logo-img  { height: 28px; }

  /* Tight paddings */
  .contact__inner          { padding: 20px 14px; }
  .download-cta__content   { padding: 28px 16px; }
  .review-card             { padding: 24px 18px; }
  .section-header          { margin-bottom: 32px; }
  .btn--lg { font-size: 0.875rem; padding: 11px 20px; }
}

/* ════════════════════════════════════════════════════════════
   Large screens — scale up
   ════════════════════════════════════════════════════════════ */
@media (min-width: 1440px) {
  .container, .hero__container, .nav__container { max-width: 1360px; }
  .hero__title { font-size: clamp(3rem, 4.5vw, 5rem); }
  .phone-mockup--hero .phone-mockup__frame { width: 310px; height: 620px; }
}

@media (min-width: 1920px) {
  html { font-size: 18px; }
  :root { --nav-h: 80px; }
  .container, .hero__container, .nav__container { max-width: 1680px; }
  .phone-mockup--hero .phone-mockup__frame  { width: 340px; height: 680px; border-radius: 52px; }
  #mockups .mockups__grid .phone-mockup--sm .phone-mockup__frame { width: 360px; height: 720px; border-radius: 56px; }
  .features__grid { grid-template-columns: repeat(4, 1fr); }
}

@media (min-width: 2560px) {
  html { font-size: 20px; }
  .container, .hero__container, .nav__container  { max-width: 2100px; }
  #mockups .mockups__grid .phone-mockup--sm .phone-mockup__frame { width: 420px; height: 840px; }
}

@media (min-width: 3840px) {
  html { font-size: 24px; }
  .container, .hero__container, .nav__container { max-width: 2800px; }
  :root { --nav-h: 96px; --radius-lg: 28px; --radius-xl: 40px; }
  .nav__logo-img { height: 56px; }
}

