/* =====================================================
   AppAdd – Premium Dark Theme 2026
   ===================================================== */

/* Google Fonts loaded via <link> in HTML for performance — no @import here */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --primary:        #7C3AED;
  --primary-mid:    #8B5CF6;
  --primary-light:  rgba(124,58,237,.15);
  --accent:         #EC4899;
  --green:          #10B981;

  --bg:             #06061A;
  --bg-surface:     #0C0C26;
  --bg-alt:         #090918;
  --bg-card:        rgba(255,255,255,.04);
  --bg-card-hover:  rgba(255,255,255,.07);

  --border:         rgba(255,255,255,.07);
  --border-subtle:  rgba(255,255,255,.04);
  --border-glow:    rgba(124,58,237,.4);

  --text-1: #FFFFFF;
  --text-2: rgba(255,255,255,.75);
  --text-3: rgba(255,255,255,.48);
  --text-4: rgba(255,255,255,.28);

  --gradient:       linear-gradient(135deg, #7C3AED 0%, #EC4899 100%);
  --gradient-blue:  linear-gradient(135deg, #4F46E5 0%, #7C3AED 100%);
  --gradient-soft:  linear-gradient(135deg, rgba(124,58,237,.12) 0%, rgba(236,72,153,.06) 100%);

  --glow-xs: 0 0 16px rgba(124,58,237,.2);
  --glow-sm: 0 0 32px rgba(124,58,237,.28);
  --glow-md: 0 0 56px rgba(124,58,237,.38);
  --glow-lg: 0 0 80px rgba(124,58,237,.45);

  --shadow-sm: 0 2px 8px rgba(0,0,0,.35);
  --shadow-md: 0 8px 32px rgba(0,0,0,.45);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.55);
  --shadow-xl: 0 32px 80px rgba(0,0,0,.65);

  --radius-sm: 8px;
  --radius:    14px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --radius-2xl:36px;

  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ease: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── Animations ─────────────────────────────────── */
@keyframes orb-a {
  0%,100% { transform: translate(0,0) scale(1); }
  33%      { transform: translate(30px,-50px) scale(1.1); }
  66%      { transform: translate(-25px,25px) scale(0.93); }
}
@keyframes orb-b {
  0%,100% { transform: translate(0,0) scale(1); }
  33%      { transform: translate(-40px,35px) scale(1.07); }
  66%      { transform: translate(30px,-25px) scale(0.96); }
}
@keyframes fade-up {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes tile-in {
  from { opacity:0; transform:translateX(20px); }
  to   { opacity:1; transform:translateX(0); }
}
@keyframes pulse-glow {
  0%,100% { box-shadow: var(--glow-xs); }
  50%      { box-shadow: var(--glow-sm); }
}

/* ── Base ───────────────────────────────────────── */
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden; /* prevent horizontal scroll from orbs/blur */
}

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text-1);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width:100%; height:auto; display:block; }
a   { color: var(--primary-mid); text-decoration: none; }
h1,h2,h3,h4,h5,h6 { line-height:1.2; color:var(--text-1); font-weight:700; }
p   { color: var(--text-2); }
button { font-family: var(--font); }

/* ── Layout ─────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 24px; }

.section     { padding:100px 0; }
.section-sm  { padding:68px 0; }
.section-alt { background: var(--bg-alt); }

.section-heading { text-align:center; margin-bottom:64px; }
.section-heading h2 {
  font-size: clamp(1.875rem, 3.8vw, 2.625rem);
  margin-bottom: 16px;
  letter-spacing: -0.03em;
  background: linear-gradient(135deg, #fff 30%, rgba(255,255,255,.55));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-heading p {
  color: var(--text-3);
  max-width: 520px;
  margin: 0 auto;
  font-size: 1.0625rem;
  line-height: 1.8;
}
.section-heading .section-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--primary-light);
  border: 1px solid rgba(124,58,237,.3);
  color: #C4B5FD;
  border-radius: 20px; padding: 6px 16px;
  font-size: 0.8125rem; font-weight: 600;
  margin-bottom: 16px; letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* ── Header ─────────────────────────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 200;
  background: rgba(6,6,26,.85);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
}
.header-inner {
  display: flex; align-items: center;
  justify-content: space-between; height: 72px;
}
.site-logo { display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0; }
.logo-icon {
  width:38px; height:38px; border-radius:11px;
  background: var(--gradient);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  box-shadow: var(--glow-xs);
}
.logo-text { font-size:1.375rem; font-weight:800; color:white; letter-spacing:-0.04em; }
.logo-text span { color: var(--primary-mid); }

.site-nav { display:flex; align-items:center; gap:2px; }
.site-nav a {
  color: var(--text-3); text-decoration:none;
  font-size: 0.9375rem; font-weight:500;
  padding:7px 14px; border-radius:var(--radius-sm);
  transition: var(--ease);
}
.site-nav a:hover, .site-nav a.active { color:white; background:rgba(255,255,255,.06); }

.header-cta { display:flex; align-items:center; gap:10px; }

.nav-toggle {
  display:none; background:none; border:none;
  cursor:pointer; padding:7px; border-radius:var(--radius-sm);
  color:white; align-items:center; justify-content:center; transition:var(--ease);
}
.nav-toggle:hover { background:rgba(255,255,255,.07); }

.mobile-nav {
  display:none; flex-direction:column;
  padding:12px 16px 20px;
  background:rgba(6,6,26,.96);
  border-top:1px solid var(--border); gap:4px;
  backdrop-filter:blur(24px);
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  color:var(--text-2); text-decoration:none;
  font-size:1rem; font-weight:500;
  padding:11px 14px; border-radius:var(--radius-sm); transition:var(--ease);
}
.mobile-nav a:hover { color:white; background:rgba(255,255,255,.06); }
.mobile-nav .btn { margin-top:10px; justify-content:center; }

/* ── Buttons ─────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 24px; border-radius:var(--radius);
  font-size:0.9375rem; font-weight:700;
  letter-spacing:0.01em;
  text-decoration:none; cursor:pointer; border:none;
  transition:var(--ease); white-space:nowrap; line-height:1;
  position:relative; overflow:hidden; flex-shrink:0;
}
/* Subtle inner highlight on hover */
.btn::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(160deg,rgba(255,255,255,.14) 0%,transparent 60%);
  opacity:0; transition:opacity .25s; pointer-events:none;
}
.btn:hover::after { opacity:1; }

/* ── Primary: purple→pink gradient, always vivid ── */
.btn-primary {
  background:var(--gradient);
  color:#fff;
  box-shadow:0 2px 14px rgba(124,58,237,.4), 0 1px 3px rgba(0,0,0,.3);
}
.btn-primary:hover {
  transform:translateY(-2px);
  box-shadow:0 6px 28px rgba(124,58,237,.55), 0 2px 8px rgba(0,0,0,.25);
  color:#fff;
}
.btn-primary:active { transform:translateY(0); }

/* ── Secondary: visible glass with purple tint ── */
.btn-secondary {
  background:rgba(124,58,237,.18);
  color:#C4B5FD;
  border:1.5px solid rgba(124,58,237,.42);
}
.btn-secondary:hover {
  background:rgba(124,58,237,.3);
  border-color:rgba(124,58,237,.65);
  color:#fff;
  transform:translateY(-2px);
  box-shadow:0 4px 20px rgba(124,58,237,.28);
}
.btn-secondary:active { transform:translateY(0); }

/* ── Ghost: frosted white, used on gradient/dark bg ── */
.btn-ghost {
  background:rgba(255,255,255,.14);
  color:#fff;
  border:1.5px solid rgba(255,255,255,.32);
  backdrop-filter:blur(8px);
}
.btn-ghost:hover {
  background:rgba(255,255,255,.24);
  border-color:rgba(255,255,255,.5);
  color:#fff;
  transform:translateY(-2px);
  box-shadow:0 4px 20px rgba(0,0,0,.2);
}

/* ── Play: Google Play green ── */
.btn-play {
  background:linear-gradient(135deg,#01875f,#06a375);
  color:#fff;
  border:1.5px solid rgba(1,135,95,.5);
  box-shadow:0 2px 12px rgba(1,135,95,.35);
}
.btn-play:hover {
  background:linear-gradient(135deg,#016b4c,#01875f);
  transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(1,135,95,.5);
  color:#fff;
}
.btn-play:active { transform:translateY(0); }

/* ── Outline: transparent with border, for light bg ── */
.btn-outline {
  background:transparent;
  color:var(--primary-mid);
  border:2px solid rgba(124,58,237,.5);
}
.btn-outline:hover {
  background:rgba(124,58,237,.1);
  border-color:var(--primary);
  color:var(--primary);
  transform:translateY(-2px);
}

/* ── Sizes ── */
.btn-sm  { padding:8px 18px; font-size:0.8125rem; border-radius:10px; gap:6px; }
.btn-lg  { padding:15px 36px; font-size:1.0625rem; border-radius:var(--radius-lg); }
.btn-xl  { padding:18px 44px; font-size:1.125rem;  border-radius:var(--radius-lg); }

/* ── Light mode button overrides ── */
/* ── Badges ─────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:4px 12px; border-radius:20px;
  font-size:0.8125rem; font-weight:600; line-height:1;
}
.badge-indigo { background:rgba(79,70,229,.15);  color:#A5B4FC; border:1px solid rgba(79,70,229,.25); }
.badge-violet { background:rgba(124,58,237,.15); color:#C4B5FD; border:1px solid rgba(124,58,237,.25); }
.badge-blue   { background:rgba(29,78,216,.15);  color:#93C5FD; border:1px solid rgba(29,78,216,.25); }
.badge-green  { background:rgba(16,185,129,.15); color:#6EE7B7; border:1px solid rgba(16,185,129,.25); }
.badge-orange { background:rgba(234,88,12,.15);  color:#FDBA74; border:1px solid rgba(234,88,12,.25); }
.badge-pink   { background:rgba(236,72,153,.15); color:#F9A8D4; border:1px solid rgba(236,72,153,.25); }
.badge-gray   { background:rgba(255,255,255,.06);color:var(--text-3); border:1px solid var(--border); }

/* ── Base Card ─────────────────────────────────── */
.card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:24px;
  backdrop-filter:blur(12px); transition:var(--ease);
}
.card:hover {
  background:var(--bg-card-hover); border-color:var(--border-glow);
  box-shadow:var(--glow-xs); transform:translateY(-3px);
}

/* ── App Cards ─────────────────────────────────── */
.app-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:24px;
  backdrop-filter:blur(12px); transition:var(--ease);
  display:flex; flex-direction:column; gap:14px;
}
.app-card:hover {
  background:var(--bg-card-hover); border-color:var(--border-glow);
  box-shadow:var(--glow-sm); transform:translateY(-4px);
}
.app-card-header { display:flex; align-items:flex-start; gap:14px; }
.app-card-icon {
  width:58px; height:58px; border-radius:16px;
  background:var(--gradient);
  display:flex; align-items:center; justify-content:center;
  font-size:26px; flex-shrink:0; box-shadow:var(--glow-xs);
}
.app-card-meta { flex:1; min-width:0; }
.app-card-name {
  font-size:1.0625rem; font-weight:700; color:var(--text-1);
  margin-bottom:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.app-card-desc { color:var(--text-3); font-size:0.9375rem; line-height:1.6; }
.app-card-footer { display:flex; gap:8px; flex-wrap:wrap; margin-top:auto; }

/* ── Blog Cards ─────────────────────────────────── */
.blog-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden;
  backdrop-filter:blur(12px); transition:var(--ease);
  display:flex; flex-direction:column;
}
.blog-card:hover {
  background:var(--bg-card-hover); border-color:var(--border-glow);
  box-shadow:var(--glow-sm); transform:translateY(-4px);
}
.blog-card-thumb {
  height:176px; display:flex; align-items:center;
  justify-content:center; font-size:3rem; flex-shrink:0;
  background: var(--gradient-soft) !important;
  border-bottom:1px solid var(--border);
}
.blog-card-body { padding:20px; flex:1; display:flex; flex-direction:column; gap:10px; }
.blog-card-title {
  font-size:1.0625rem; font-weight:700;
  color:var(--text-1); line-height:1.4; transition:color .15s;
}
.blog-card:hover .blog-card-title { color:var(--primary-mid); }
.blog-card-desc { color:var(--text-3); font-size:0.9375rem; line-height:1.6; flex:1; }
.blog-card-meta {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
  font-size:0.8125rem; color:var(--text-4); margin-top:auto;
}
.blog-card-meta span { display:flex; align-items:center; gap:4px; }

/* ── Category Cards ─────────────────────────────── */
.category-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:36px 24px;
  text-align:center; backdrop-filter:blur(12px); transition:var(--ease);
  display:flex; flex-direction:column; align-items:center; gap:14px;
}
.category-card:hover {
  background:var(--bg-card-hover); border-color:var(--border-glow);
  box-shadow:var(--glow-sm); transform:translateY(-5px);
}
.category-icon {
  width:72px; height:72px; border-radius:22px;
  background:var(--gradient);
  display:flex; align-items:center; justify-content:center;
  font-size:30px; box-shadow:var(--glow-xs);
}
.category-card h3 { font-size:1.125rem; color:var(--text-1); margin:0; }
.category-card p  { color:var(--text-3); font-size:0.9375rem; margin:0; line-height:1.6; }
.category-count   { font-size:0.875rem; color:var(--text-4); }

/* ── Hero ───────────────────────────────────────── */
.hero {
  position:relative; overflow:hidden;
  padding:128px 0 108px;
  background:var(--bg); color:white;
}
/* Animated orb 1 – purple */
.hero::before {
  content:''; position:absolute;
  top:-10%; left:8%;
  width:640px; height:640px; border-radius:50%;
  background:radial-gradient(circle, rgba(124,58,237,.38) 0%, transparent 68%);
  animation:orb-a 14s ease-in-out infinite;
  pointer-events:none; filter:blur(48px); z-index:0;
}
/* Animated orb 2 – pink */
.hero::after {
  content:''; position:absolute;
  bottom:-20%; right:5%;
  width:560px; height:560px; border-radius:50%;
  background:radial-gradient(circle, rgba(236,72,153,.3) 0%, transparent 68%);
  animation:orb-b 18s ease-in-out infinite;
  pointer-events:none; filter:blur(48px); z-index:0;
}
.hero-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr;
  gap:72px; align-items:center;
}

.hero-content { animation:fade-up .7s ease both; }

.hero-tag {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(124,58,237,.15);
  border:1px solid rgba(124,58,237,.38);
  border-radius:20px; padding:7px 18px;
  font-size:0.875rem; font-weight:600;
  color:#C4B5FD; margin-bottom:28px;
  backdrop-filter:blur(8px);
}

.hero h1 {
  font-size:clamp(2.375rem, 5.5vw, 3.75rem);
  font-weight:800; letter-spacing:-0.04em;
  line-height:1.08; margin-bottom:24px;
  background:linear-gradient(160deg, #FFFFFF 0%, rgba(255,255,255,.88) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero p {
  font-size:1.125rem; color:var(--text-3);
  margin-bottom:44px; line-height:1.85; max-width:480px;
}

.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }

.hero-stats {
  display:flex; gap:40px; margin-top:56px; flex-wrap:wrap;
  padding-top:40px; border-top:1px solid var(--border);
}
.hero-stat-num {
  font-size:1.875rem; font-weight:800;
  background:var(--gradient);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-stat-lbl { font-size:0.875rem; color:var(--text-4); margin-top:4px; }

/* Hero visual */
.hero-visual {
  display:flex; justify-content:flex-end;
  align-items:center; position:relative; z-index:1;
  animation:tile-in .8s ease .2s both;
}
.hero-app-stack { display:flex; flex-direction:column; gap:14px; width:100%; max-width:330px; }
.hero-app-tile {
  display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  border-radius:var(--radius-lg); padding:18px 22px;
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  transition:var(--ease); text-decoration:none;
}
.hero-app-tile:hover {
  background:rgba(255,255,255,.09);
  border-color:var(--border-glow);
  box-shadow:var(--glow-xs);
  transform:translateX(-5px);
}
.hero-app-em    { font-size:32px; line-height:1; flex-shrink:0; }
.hero-app-ttl   { font-size:0.9375rem; font-weight:700; color:white; }
.hero-app-sub   { font-size:0.8125rem; color:var(--text-4); margin-top:2px; }
.hero-app-arrow { margin-left:auto; color:var(--text-4); flex-shrink:0; transition:var(--ease); }
.hero-app-tile:hover .hero-app-arrow { color:var(--primary-mid); transform:translateX(4px); }

/* ── Page Hero ─────────────────────────────────── */
.page-hero {
  background:var(--bg-surface);
  border-bottom:1px solid var(--border);
  padding:80px 0 68px; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; top:-50%; right:-8%;
  width:480px; height:480px; border-radius:50%;
  background:radial-gradient(circle, rgba(124,58,237,.22) 0%, transparent 70%);
  filter:blur(48px); pointer-events:none;
}
.page-hero.dark { background:var(--bg); }
.page-hero h1 {
  font-size:clamp(1.875rem, 4vw, 2.875rem);
  letter-spacing:-0.03em; margin-bottom:14px;
  background:linear-gradient(135deg, #fff 0%, rgba(255,255,255,.7));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.page-hero p { font-size:1.0625rem; color:var(--text-3); max-width:600px; line-height:1.8; }

/* ── Breadcrumb ─────────────────────────────────── */
.breadcrumb {
  display:flex; align-items:center; gap:6px; flex-wrap:wrap;
  font-size:0.875rem; color:var(--text-4); margin-bottom:22px;
}
.breadcrumb a { color:var(--text-4); transition:color .15s; }
.breadcrumb a:hover { color:var(--primary-mid); }
.breadcrumb-sep { color:var(--text-4); font-size:.75rem; opacity:.5; }
.breadcrumb-cur { color:var(--text-2); font-weight:500; }

.breadcrumb.light a, .breadcrumb.light { color:var(--text-4); }
.breadcrumb.light a:hover { color:white; }
.breadcrumb.light .breadcrumb-cur { color:var(--text-2); }

/* ── Grids ───────────────────────────────────────── */
.grid-2    { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.grid-3    { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-4    { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.grid-auto { grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }

/* ── Feature Items ──────────────────────────────── */
.features-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:16px;
}
.feature-item {
  display:flex; gap:16px; padding:24px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); backdrop-filter:blur(12px);
  transition:var(--ease);
}
.feature-item:hover {
  background:var(--bg-card-hover); border-color:var(--border-glow);
  box-shadow:var(--glow-xs); transform:translateY(-3px);
}
.feature-icon {
  width:48px; height:48px; border-radius:14px;
  background:var(--gradient); color:white;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; box-shadow:var(--glow-xs);
}
.feature-text h3 { font-size:1rem; margin-bottom:5px; color:var(--text-1); }
.feature-text p  { font-size:0.9375rem; color:var(--text-3); margin:0; }

/* ── App Feature Cards ──────────────────────────── */
.app-features-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr)); gap:16px;
}
.app-feature-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); padding:20px;
  display:flex; gap:13px; align-items:flex-start;
  backdrop-filter:blur(12px); transition:var(--ease);
}
.app-feature-card:hover { background:var(--bg-card-hover); border-color:var(--border-glow); }
.af-icon {
  width:40px; height:40px; border-radius:10px;
  background:var(--gradient); color:white;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.af-text h4 { font-size:0.9375rem; margin-bottom:4px; color:var(--text-1); }
.af-text p  { font-size:0.875rem; color:var(--text-3); margin:0; }

/* ── Steps ──────────────────────────────────────── */
.steps-list { list-style:none; display:flex; flex-direction:column; gap:18px; }
.step-item  { display:flex; gap:16px; align-items:flex-start; }
.step-num {
  width:38px; height:38px; border-radius:50%;
  background:var(--gradient); color:white;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:0.9375rem; flex-shrink:0;
  box-shadow:var(--glow-xs);
}
.step-body h4 { font-size:1rem; margin-bottom:5px; color:var(--text-1); }
.step-body p  { font-size:0.9375rem; color:var(--text-3); margin:0; }

/* ── Use Cases ──────────────────────────────────── */
.use-cases { display:flex; flex-direction:column; gap:12px; }
.use-case {
  display:flex; gap:13px; align-items:flex-start;
  padding:18px; background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); backdrop-filter:blur(8px);
}
.use-case-check {
  width:28px; height:28px; border-radius:50%;
  background:rgba(16,185,129,.15); color:#10B981;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  border:1px solid rgba(16,185,129,.28);
}
.use-case p { font-size:0.9375rem; color:var(--text-2); margin:0; }

/* ── FAQ ────────────────────────────────────────── */
.faq-list  { display:flex; flex-direction:column; gap:8px; }
.faq-item {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  backdrop-filter:blur(12px); transition:border-color .25s;
}
.faq-item:hover, .faq-item.open { border-color:var(--border-glow); }
.faq-q {
  display:flex; justify-content:space-between; align-items:center;
  padding:18px 22px; cursor:pointer; font-weight:600;
  font-size:1rem; user-select:none; gap:12px; transition:var(--ease);
  color:var(--text-1);
}
.faq-q:hover { background:rgba(255,255,255,.03); }
.faq-icon {
  width:26px; height:26px; border-radius:50%;
  background:var(--primary-light); color:var(--primary-mid);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:transform .25s ease;
}
.faq-item.open .faq-icon { transform:rotate(45deg); background:var(--gradient); color:white; }
.faq-a {
  padding:0 22px; max-height:0; overflow:hidden;
  transition:max-height .32s ease, padding .25s ease;
}
.faq-item.open .faq-a { padding:0 22px 18px; max-height:500px; }
.faq-a p { font-size:0.9375rem; color:var(--text-3); margin:0; line-height:1.8; }

/* ── Screenshots ────────────────────────────────── */
.screenshots-row {
  display:flex; gap:16px; overflow-x:auto; padding-bottom:8px;
  scrollbar-width:thin; scrollbar-color:var(--border) transparent;
}
.screenshot-card {
  width:148px; min-width:148px; height:260px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:20px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:8px;
  font-size:2rem; color:var(--text-3);
}
.screenshot-card span { font-size:0.8125rem; color:var(--text-4); }

/* ── App Detail ─────────────────────────────────── */
.app-detail-hero { display:grid; grid-template-columns:1fr auto; gap:40px; align-items:start; }
.app-icon-lg {
  width:88px; height:88px; border-radius:22px;
  background:var(--gradient);
  display:flex; align-items:center; justify-content:center;
  font-size:40px; margin-bottom:20px; box-shadow:var(--glow-md);
}
.app-detail-hero h1 {
  font-size:clamp(1.75rem, 4vw, 2.5rem);
  letter-spacing:-.03em; margin-bottom:12px;
  background:linear-gradient(135deg, #fff 0%, rgba(255,255,255,.72));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.app-hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:24px; }
.app-hero-screenshots { display:flex; gap:12px; }
.app-mini-screenshot {
  width:130px; height:220px;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:16px; display:flex; align-items:center;
  justify-content:center; font-size:2rem; flex-shrink:0;
}

/* ── Blog Article ───────────────────────────────── */
.article-wrap    { display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; }
.article-body    { min-width:0; }
.article-sidebar { position:sticky; top:84px; }

.article-meta {
  display:flex; align-items:center; gap:18px; flex-wrap:wrap;
  margin-bottom:28px; padding-bottom:28px; border-bottom:1px solid var(--border);
}
.meta-item { display:flex; align-items:center; gap:5px; font-size:0.875rem; color:var(--text-3); }

.article-intro {
  font-size:1.0625rem; color:var(--text-2); line-height:1.85;
  margin-bottom:28px; padding-bottom:28px; border-bottom:1px solid var(--border);
}
.article-body h2 { font-size:1.5rem; margin:40px 0 14px; letter-spacing:-.025em; color:var(--text-1); }
.article-body h3 { font-size:1.1875rem; margin:28px 0 10px; color:var(--text-1); }
.article-body p  { font-size:1rem; line-height:1.85; color:var(--text-2); margin-bottom:18px; }
.article-body ul, .article-body ol { padding-left:22px; margin-bottom:18px; }
.article-body li { font-size:1rem; color:var(--text-2); margin-bottom:8px; line-height:1.75; }
.article-body strong { color:var(--text-1); }

.toc-box {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); padding:22px; margin-bottom:24px;
  backdrop-filter:blur(12px);
}
.toc-box h4 {
  font-size:0.8125rem; margin-bottom:14px; color:var(--text-3);
  text-transform:uppercase; letter-spacing:.07em;
}
.toc-box ol { padding-left:18px; display:flex; flex-direction:column; gap:9px; }
.toc-box a  { color:var(--text-3); font-size:0.9375rem; transition:color .15s; }
.toc-box a:hover { color:var(--primary-mid); }

.toc-mobile {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); padding:18px 20px; margin-bottom:28px; display:none;
}
.toc-mobile h4 { font-size:0.875rem; margin-bottom:12px; color:var(--text-3); }
.toc-mobile ol { padding-left:18px; display:flex; flex-direction:column; gap:7px; }
.toc-mobile a  { color:var(--text-3); font-size:0.9375rem; }
.toc-mobile a:hover { color:var(--primary-mid); }

.sidebar-app-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:20px;
  display:flex; flex-direction:column; gap:12px;
  backdrop-filter:blur(12px);
}
.sidebar-app-card h4 { font-size:0.9375rem; color:var(--text-3); text-transform:uppercase; letter-spacing:.06em; }

/* ── CTA Section ────────────────────────────────── */
.cta-section {
  position:relative; overflow:hidden;
  padding:108px 0; text-align:center; color:white;
  background:var(--bg-surface);
}
.cta-section::before {
  content:''; position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:700px; height:500px; border-radius:50%;
  background:radial-gradient(ellipse, rgba(124,58,237,.3) 0%, rgba(236,72,153,.14) 50%, transparent 70%);
  filter:blur(48px); pointer-events:none;
}
.cta-section h2 {
  color:white; font-size:clamp(2rem, 4vw, 2.75rem);
  margin-bottom:20px; letter-spacing:-.035em; position:relative;
  background:linear-gradient(135deg, #fff 0%, rgba(255,255,255,.72));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.cta-section p {
  color:var(--text-3); max-width:480px; margin:0 auto 44px;
  font-size:1.0625rem; line-height:1.8; position:relative;
}
.btn-group { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; position:relative; }

/* ── CTA Box ────────────────────────────────────── */
.cta-box {
  background:var(--gradient-soft);
  border:1px solid rgba(124,58,237,.28);
  border-radius:var(--radius-lg); padding:28px;
  display:flex; align-items:center; gap:20px;
  flex-wrap:wrap; margin:36px 0; backdrop-filter:blur(12px);
}
.cta-box-icon {
  width:54px; height:54px; border-radius:14px;
  background:var(--gradient);
  display:flex; align-items:center; justify-content:center;
  font-size:24px; flex-shrink:0; box-shadow:var(--glow-xs);
}
.cta-box-body { flex:1; min-width:180px; }
.cta-box-body h3 { font-size:1.0625rem; margin-bottom:5px; color:var(--text-1); }
.cta-box-body p  { font-size:0.9375rem; color:var(--text-3); margin:0; }
.cta-box-actions { display:flex; gap:8px; flex-wrap:wrap; }

/* ── Ad Placeholder ─────────────────────────────── */
.ad-placeholder {
  background:var(--bg-card); border:1px dashed rgba(255,255,255,.1);
  border-radius:var(--radius); padding:36px 24px; text-align:center; margin:32px 0;
}
.ad-lbl  { font-size:0.75rem; color:var(--text-4); letter-spacing:.08em; text-transform:uppercase; margin-bottom:5px; }
.ad-size { font-size:0.875rem; color:var(--text-3); }

/* ── Filter Bar ─────────────────────────────────── */
.filter-bar {
  display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:36px;
}
.search-wrap { position:relative; flex:1; min-width:200px; max-width:320px; }
.search-wrap svg {
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  color:var(--text-4); pointer-events:none;
}
.search-input {
  width:100%; padding:10px 14px 10px 40px;
  border:1px solid var(--border); border-radius:10px;
  font-size:0.9375rem; background:var(--bg-card); color:var(--text-1);
  outline:none; transition:var(--ease); font-family:var(--font);
}
.search-input:focus { border-color:var(--border-glow); box-shadow:0 0 0 3px rgba(124,58,237,.18); }
.search-input::placeholder { color:var(--text-4); }

.filter-buttons { display:flex; gap:8px; flex-wrap:wrap; }
.filter-btn {
  padding:8px 17px; border-radius:8px;
  font-size:0.875rem; font-weight:500; cursor:pointer;
  border:1px solid var(--border); background:var(--bg-card);
  color:var(--text-3); transition:var(--ease); font-family:var(--font);
}
.filter-btn:hover, .filter-btn.active {
  background:var(--primary-light); border-color:var(--border-glow); color:var(--primary-mid);
}

/* ── Featured Blog ──────────────────────────────── */
.featured-blog {
  display:grid; grid-template-columns:1fr 1.1fr; gap:0; align-items:center;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); overflow:hidden;
  box-shadow:var(--shadow-md); margin-bottom:48px; backdrop-filter:blur(12px);
}
.featured-blog-img {
  height:100%; min-height:280px;
  background:var(--gradient-soft) !important;
  display:flex; align-items:center; justify-content:center; font-size:5rem;
  border-right:1px solid var(--border);
}
.featured-blog-body { padding:36px; }
.featured-blog-body .blog-card-title { font-size:1.375rem; margin-bottom:10px; color:var(--text-1); }
.featured-blog-body .blog-card-desc  { margin-bottom:18px; }

/* ── Prose ──────────────────────────────────────── */
.prose h2     { font-size:1.5rem; margin:44px 0 16px; letter-spacing:-.025em; color:var(--text-1); }
.prose h3     { font-size:1.125rem; margin:28px 0 10px; color:var(--text-1); }
.prose p      { font-size:1rem; color:var(--text-2); line-height:1.85; margin-bottom:16px; }
.prose ul, .prose ol { padding-left:22px; margin-bottom:16px; }
.prose li     { font-size:1rem; color:var(--text-2); margin-bottom:8px; line-height:1.75; }

/* ── Contact ────────────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1fr minmax(0,320px); gap:48px; align-items:start; }
.contact-info-item {
  display:flex; gap:14px; align-items:flex-start;
  padding:20px; background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); margin-bottom:14px; backdrop-filter:blur(8px);
}
.ci-icon {
  width:44px; height:44px; border-radius:11px;
  background:var(--gradient); color:white;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  box-shadow:var(--glow-xs);
}
.ci-label { font-size:0.8125rem; color:var(--text-4); margin-bottom:3px; font-weight:500; }
.ci-val   { font-size:1rem; font-weight:600; color:var(--text-1); }

.form-group { margin-bottom:20px; }
.form-label { display:block; font-size:0.9375rem; font-weight:600; color:var(--text-1); margin-bottom:7px; }
.form-input, .form-select, .form-textarea {
  width:100%; padding:11px 14px; border:1px solid var(--border);
  border-radius:10px; font-size:1rem; color:var(--text-1);
  background:var(--bg-card); font-family:var(--font); transition:var(--ease); outline:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color:var(--border-glow); box-shadow:0 0 0 3px rgba(124,58,237,.18);
}
.form-textarea { resize:vertical; min-height:130px; }

/* ── About ──────────────────────────────────────── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.about-visual {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); padding:40px;
  display:flex; flex-direction:column; gap:14px; backdrop-filter:blur(12px);
}
.about-stat {
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  border-radius:var(--radius); padding:20px; text-align:center;
}
.about-stat-num {
  font-size:1.75rem; font-weight:800;
  background:var(--gradient);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.about-stat-lbl { font-size:0.875rem; color:var(--text-3); margin-top:4px; }

/* ── Back to Top ────────────────────────────────── */
.back-to-top {
  position:fixed; bottom:24px; right:24px;
  width:48px; height:48px; background:var(--gradient);
  color:white; border:none; border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; box-shadow:var(--glow-xs);
  opacity:0; pointer-events:none;
  transition:opacity .25s, transform .2s; z-index:100;
}
.back-to-top.visible { opacity:1; pointer-events:auto; }
.back-to-top:hover   { transform:translateY(-3px); box-shadow:var(--glow-sm); }

/* ── Footer ─────────────────────────────────────── */
.site-footer {
  background:var(--bg-surface); color:var(--text-4);
  padding-top:88px; border-top:1px solid var(--border);
}
.footer-grid {
  display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr;
  gap:44px; padding-bottom:60px; border-bottom:1px solid var(--border);
}
.footer-brand .logo-text { color:white; }
.footer-brand p { color:var(--text-4); font-size:0.9375rem; margin:14px 0 18px; line-height:1.8; }
.footer-email a { color:var(--text-3); font-size:0.9375rem; transition:color .15s; }
.footer-email a:hover { color:var(--primary-mid); }

.footer-section h4 {
  color:var(--text-2); font-size:0.8125rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:20px;
}
.footer-section ul { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-section li a { color:var(--text-4); font-size:0.9375rem; transition:color .15s; }
.footer-section li a:hover { color:var(--primary-mid); }

.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding:24px 0; gap:16px; flex-wrap:wrap;
}
.footer-copy   { font-size:0.875rem; color:var(--text-4); }
.footer-legal  { display:flex; gap:20px; flex-wrap:wrap; }
.footer-legal a { color:var(--text-4); font-size:0.875rem; transition:color .15s; }
.footer-legal a:hover { color:var(--primary-mid); }

/* ── Theme Toggle Button ────────────────────────── */
.theme-toggle {
  width:40px; height:40px; border-radius:var(--radius-sm);
  background:rgba(255,255,255,.07); border:1px solid var(--border);
  color:var(--text-2); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--ease); flex-shrink:0;
}
.theme-toggle:hover { background:rgba(255,255,255,.13); color:white; }
/* dark mode: show sun (click to go light) */
.theme-toggle .icon-sun  { display:block; }
.theme-toggle .icon-moon { display:none; }
/* light mode: show moon (click to go dark) */
/* ── Hero Search Bar ────────────────────────────── */
.hero-search-bar { margin-bottom:22px; }
.hero-search-inner {
  display:flex; align-items:center; gap:0;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius-lg);
  padding:6px 6px 6px 18px;
  backdrop-filter:blur(16px);
  transition:border-color .25s, box-shadow .25s;
  max-width:520px;
}
.hero-search-inner:focus-within {
  border-color:rgba(124,58,237,.55);
  box-shadow:0 0 0 3px rgba(124,58,237,.18);
}
.hero-search-icon { color:var(--text-4); flex-shrink:0; }
.hero-search-input {
  flex:1; background:none; border:none; outline:none;
  font-family:var(--font); font-size:1rem; color:var(--text-1);
  padding:9px 12px;
}
.hero-search-input::placeholder { color:var(--text-4); }
.hero-search-btn {
  background:var(--gradient); color:white;
  border:none; border-radius:var(--radius);
  padding:10px 24px; font-size:0.9375rem; font-weight:600;
  cursor:pointer; font-family:var(--font); transition:var(--ease); flex-shrink:0;
}
.hero-search-btn:hover { transform:translateY(-1px); box-shadow:var(--glow-xs); }

/* ── Hero Quick Chips ───────────────────────────── */
.hero-quick { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.hero-quick-label { font-size:0.875rem; color:var(--text-4); }
.hero-chip {
  display:inline-flex; align-items:center; gap:5px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px; padding:5px 14px;
  font-size:0.8125rem; font-weight:500; color:var(--text-2);
  text-decoration:none; transition:var(--ease);
}
.hero-chip:hover {
  background:rgba(124,58,237,.2);
  border-color:rgba(124,58,237,.45);
  color:#C4B5FD;
}

/* ── Hero Phone Mockup ──────────────────────────── */
@keyframes float-badge-a {
  0%,100% { transform:translateY(0) rotate(-2deg); }
  50%      { transform:translateY(-10px) rotate(-2deg); }
}
@keyframes float-badge-b {
  0%,100% { transform:translateY(0) rotate(2deg); }
  50%      { transform:translateY(10px) rotate(2deg); }
}
@keyframes pulse-glow-hero {
  0%,100% { opacity:.7; transform:scale(1); }
  50%      { opacity:1; transform:scale(1.08); }
}

.hero-phone-wrap {
  position:relative;
  display:flex; align-items:center; justify-content:flex-end;
  width:100%; padding-right:24px;
}
.hero-phone-glow {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:340px; height:400px; border-radius:50%;
  background:radial-gradient(ellipse, rgba(124,58,237,.45) 0%, rgba(236,72,153,.22) 50%, transparent 70%);
  filter:blur(40px); z-index:0; pointer-events:none;
  animation:pulse-glow-hero 5s ease-in-out infinite;
}
.hero-phone {
  position:relative; z-index:1;
  width:260px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.13);
  border-radius:38px;
  padding:20px 18px 22px;
  backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
  box-shadow:0 40px 80px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.12);
}
.hero-phone-head {
  display:flex; justify-content:center; margin-bottom:16px;
}
.hero-phone-notch {
  width:72px; height:5px; border-radius:3px;
  background:rgba(255,255,255,.18);
}
.hero-phone-search-mini {
  display:flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px; padding:9px 12px;
  margin-bottom:14px; color:rgba(255,255,255,.3);
  font-size:0.8125rem;
}
.hero-phone-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:10px;
  margin-bottom:14px;
}
.hero-pa {
  aspect-ratio:1; border-radius:18px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px;
  box-shadow:0 4px 14px rgba(0,0,0,.35);
  transition:transform .2s ease;
}
.hero-pa:hover { transform:scale(1.06); }
.hero-phone-feat {
  display:flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px; padding:12px 14px;
}
.hero-pf-icon { font-size:22px; flex-shrink:0; }
.hero-pf-name { font-size:0.8rem; font-weight:700; color:white; line-height:1.3; }
.hero-pf-cat  { font-size:0.75rem; color:rgba(255,255,255,.35); margin-top:2px; }
.hero-pf-arrow { margin-left:auto; color:rgba(255,255,255,.3); flex-shrink:0; }

.hero-float-1, .hero-float-2 {
  position:absolute; z-index:2;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  border-radius:20px; padding:7px 16px;
  font-size:0.8125rem; font-weight:600;
  color:white; backdrop-filter:blur(16px);
  white-space:nowrap;
}
.hero-float-1 { top:18%; left:-10px; animation:float-badge-a 4.5s ease-in-out infinite; }
.hero-float-2 { bottom:22%; right:-14px; animation:float-badge-b 5.5s ease-in-out infinite; }

/* ── Light Mode ─────────────────────────────────── */
/* Header */
/* Hero light */
/* Search light */
/* Chips light */
/* Phone mockup light */
/* Section headings light */
/* Page hero light */
/* CTA section light (keep gradient) */
/* Feature items light */
/* Footer stays dark in both modes */
/* ── Animations ─────────────────────────────────── */

/* Page fade-in on load */
@keyframes page-fade-in {
  from { opacity:0; }
  to   { opacity:1; }
}
body { animation:page-fade-in 0.38s ease both; }

/* Hero background dot grid */
@keyframes grid-drift {
  from { transform:translate(0,0); }
  to   { transform:translate(30px,30px); }
}
.hero-bg-grid {
  position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden;
}
.hero-bg-grid::before {
  content:''; position:absolute; inset:-120%;
  background-image:radial-gradient(circle, rgba(255,255,255,.042) 1px, transparent 1px);
  background-size:30px 30px;
  animation:grid-drift 38s linear infinite;
}
/* Phone gentle float */
@keyframes phone-float {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-14px); }
}
.hero-phone { animation:phone-float 7s ease-in-out infinite; }

/* Scroll progress bar */
.scroll-progress {
  position:fixed; top:0; left:0; height:2px; z-index:9999;
  background:var(--gradient); width:0%;
  pointer-events:none;
}

/* Header scroll shadow */
.site-header.scrolled {
  box-shadow:0 4px 32px rgba(0,0,0,.48);
}
/* Logo hover spring */
.logo-icon { transition:transform .28s cubic-bezier(0.34, 1.56, 0.64, 1); }
.site-logo:hover .logo-icon { transform:rotate(18deg) scale(1.1); }

/* ── Scroll Reveal ───────────────────────────────── */
/* Class added by JS — if JS fails, elements stay visible */
.reveal {
  opacity:0;
  transform:translateY(28px);
  transition:opacity 0.62s cubic-bezier(0.22,1,0.36,1),
             transform 0.62s cubic-bezier(0.22,1,0.36,1);
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── Card Shimmer Sweep ───────────────────────────── */
/* Need overflow hidden on cards that don't already have it */
.app-card, .category-card, .feature-item { position:relative; overflow:hidden; }

.app-card::after, .blog-card::after, .category-card::after, .feature-item::after {
  content:''; position:absolute;
  top:0; left:-80%; width:50%; height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.05), transparent);
  transform:skewX(-18deg);
  transition:left 0s;
  pointer-events:none;
}
.app-card:hover::after, .blog-card:hover::after,
.category-card:hover::after, .feature-item:hover::after {
  left:160%;
  transition:left .65s ease;
}
/* Section tag pulse on scroll-in */
@keyframes tag-pop {
  0%   { transform:scale(.88); opacity:0; }
  70%  { transform:scale(1.04); }
  100% { transform:scale(1);   opacity:1; }
}
.section-heading.visible .section-tag { animation:tag-pop .45s cubic-bezier(0.22,1,0.36,1) both; }

/* Stagger helper delays (set by JS inline, but defined here for ref) */
.reveal { transition-delay:0ms; }

/* ── Reduced Motion ──────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .reveal { opacity:1; transform:none; transition:none; }
  body    { animation:none; }
}

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 1024px) {
  .grid-4        { grid-template-columns:repeat(2,1fr); }
  .footer-grid   { grid-template-columns:1fr 1fr; gap:32px; }
  .article-wrap  { grid-template-columns:1fr; }
  .article-sidebar { display:none; }
  .toc-mobile    { display:block; }
  .app-detail-hero { grid-template-columns:1fr; }
  .app-hero-screenshots { display:none; }
  .featured-blog { grid-template-columns:1fr; }
  .featured-blog-img { min-height:200px; border-right:none; border-bottom:1px solid var(--border); }
  .featured-blog-body { padding:28px; }
}

@media (max-width: 768px) {
  .section       { padding:60px 0; }
  .section-sm    { padding:44px 0; }
  .section-heading { margin-bottom:40px; }
  .section-heading h2 { font-size:clamp(1.5rem,6vw,2rem); }

  .site-nav, .header-cta .btn { display:none; }
  .nav-toggle { display:inline-flex; }

  /* Hero */
  .hero          { padding:72px 0 56px; }
  .hero-inner    { grid-template-columns:1fr; gap:0; }
  .hero-visual   { display:none; }
  .hero h1       { font-size:clamp(1.875rem,7vw,2.5rem); margin-bottom:16px; }
  .hero p        { font-size:1rem; margin-bottom:28px; }

  /* Shrink hero orbs so they don't bleed outside */
  .hero::before  { width:280px; height:280px; top:-5%; left:-5%; }
  .hero::after   { width:240px; height:240px; bottom:-10%; right:-5%; }

  /* Search bar stacks on very small */
  .hero-search-inner { padding:5px 5px 5px 14px; }
  .hero-search-input { font-size:0.9375rem; padding:8px 8px; }

  /* Chips wrap neatly */
  .hero-quick    { gap:6px; }
  .hero-chip     { padding:5px 12px; font-size:0.75rem; }

  .grid-3        { grid-template-columns:1fr; }
  .grid-2        { grid-template-columns:1fr; }
  .contact-grid  { grid-template-columns:1fr; }
  .about-grid    { grid-template-columns:1fr; }
  .footer-grid   { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; text-align:center; }

  /* Page heroes */
  .page-hero     { padding:52px 0 44px; }
  .page-hero h1  { font-size:clamp(1.625rem,6vw,2.25rem); }

  /* CTA */
  .cta-section   { padding:72px 0; }
  .cta-box       { flex-direction:column; }

  /* Cards */
  .app-card, .blog-card, .category-card { padding:20px; }
  .app-card-icon { width:48px; height:48px; font-size:22px; border-radius:13px; }

  /* App detail */
  .app-icon-lg   { width:72px; height:72px; font-size:32px; }

  /* Footer */
  .site-footer   { padding-top:56px; }
}

@media (max-width: 480px) {
  .container     { padding:0 14px; }

  /* Hero */
  .hero          { padding:60px 0 48px; }
  .hero h1       { font-size:1.875rem; letter-spacing:-0.03em; }
  .hero p        { font-size:0.9375rem; }
  .hero::before  { width:200px; height:200px; }
  .hero::after   { width:180px; height:180px; }

  /* Hero search: stack button below input */
  .hero-search-inner {
    flex-direction:column; align-items:stretch;
    padding:12px 14px; gap:10px; border-radius:var(--radius);
  }
  .hero-search-icon { display:none; }
  .hero-search-input { padding:0; font-size:0.9375rem; }
  .hero-search-btn   { width:100%; justify-content:center; border-radius:var(--radius-sm); }

  /* Sections */
  .section       { padding:52px 0; }
  .section-sm    { padding:36px 0; }
  .section-heading { margin-bottom:32px; }
  .page-hero     { padding:44px 0 36px; }
  .cta-section   { padding:60px 0; }

  /* Buttons */
  .hero-actions  { flex-direction:column; }
  .hero-actions .btn { justify-content:center; }
  .btn-xl        { padding:14px 24px; font-size:1rem; }
  .btn-lg        { padding:13px 26px; font-size:1rem; }

  /* Footer */
  .footer-grid   { gap:24px; }
  .footer-section h4 { margin-bottom:12px; }

  /* Blog cards - tighter on small screens */
  .blog-card-thumb { height:140px; font-size:2.5rem; }
  .grid-4 { grid-template-columns:1fr; }
}
