/* ───────── Mansia design system ───────── */
:root {
  --bg:        #0a0a0b;
  --bg-elev:   #131316;
  --bg-card:   #1a1a1f;
  --line:      #2a2a32;
  --text:      #f4f4f6;
  --text-dim:  #a0a0ad;
  --text-mute: #6b6b7a;

  --mint:      #00d4a4;
  --mint-dim:  #00d4a466;
  --warn:      #ffb84d;
  --hot:       #ff5e5e;

  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --space: clamp(16px, 4vw, 32px);

  --font: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', system-ui, sans-serif;
  --mono: ui-monospace, 'SF Mono', 'JetBrains Mono', 'Cascadia Code', monospace;

  /* Telegram WebApp variables — overridden when running inside Telegram */
  --tg-bg:        var(--bg);
  --tg-text:      var(--text);
  --tg-button:    var(--mint);
  --tg-btn-text:  #001a14;
}

/* RTL adjustments */
html[dir="rtl"] body { font-feature-settings: "liga" 1, "ss01" 1; }

* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.55;
  font-size: 16px;
  min-height: 100vh;
  text-rendering: optimizeLegibility;
}

a { color: var(--mint); text-decoration: none; transition: opacity .15s; }
a:hover { opacity: .8; }
button { font-family: inherit; font-size: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
img, svg { display: block; max-width: 100%; }

/* ───────── Layout primitives ───────── */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space);
}
.row { display: flex; align-items: center; gap: 12px; }
.stack { display: flex; flex-direction: column; gap: 12px; }

/* ───────── Top nav ───────── */
.nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(10,10,11,0.85);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 60px;
  padding: 0 var(--space);
  max-width: 1200px;
  margin: 0 auto;
}
.brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 18px; letter-spacing: -.01em;
}
.brand-mark {
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--mint);
  display: grid; place-items: center;
  color: #001a14; font-weight: 900; font-size: 16px;
}
.nav-links { display: flex; gap: 22px; font-size: 14px; color: var(--text-dim); }
.nav-links a { color: inherit; }
.nav-links a:hover { color: var(--text); }
.nav-cta {
  background: var(--mint); color: #001a14;
  padding: 8px 16px; border-radius: 999px;
  font-weight: 600; font-size: 14px;
  transition: transform .15s;
}
.nav-cta:hover { transform: scale(1.04); opacity: 1; }
@media (max-width: 720px) { .nav-links { display: none; } }

/* ───────── Hero ───────── */
.hero {
  padding: clamp(48px, 12vw, 120px) 0 clamp(60px, 12vw, 120px);
  position: relative; overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(900px circle at 80% 10%, rgba(0,212,164,.08), transparent 50%),
    radial-gradient(600px circle at 20% 90%, rgba(0,212,164,.04), transparent 50%);
  pointer-events: none;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 999px;
  background: var(--bg-elev); border: 1px solid var(--line);
  font-size: 13px; color: var(--text-dim);
  margin-bottom: 24px;
}
.hero-eyebrow .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--mint);
  box-shadow: 0 0 12px var(--mint);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }
.hero h1 {
  font-size: clamp(36px, 7vw, 72px);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.05;
  max-width: 16ch;
}
.hero h1 .accent { color: var(--mint); }
.hero p.sub {
  font-size: clamp(16px, 2.4vw, 20px);
  color: var(--text-dim);
  max-width: 56ch;
  margin-top: 24px;
}
.hero-cta { display: flex; gap: 12px; margin-top: 36px; flex-wrap: wrap; }
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 26px; border-radius: 12px;
  font-weight: 600; font-size: 15px;
  transition: transform .15s, background .15s;
}
.btn-primary {
  background: var(--mint); color: #001a14;
}
.btn-primary:hover { transform: translateY(-1px); opacity: 1; }
.btn-ghost {
  background: var(--bg-elev); color: var(--text);
  border: 1px solid var(--line);
}
.btn-ghost:hover { background: var(--bg-card); opacity: 1; }

/* ───────── Live counters strip ───────── */
.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 14px;
  margin-top: 60px;
}
.stat {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 22px 18px;
}
.stat .num {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 800; letter-spacing: -.02em;
  color: var(--mint);
  font-feature-settings: "tnum" 1;
}
.stat .lbl {
  font-size: 13px; color: var(--text-dim);
  margin-top: 4px;
}

/* ───────── Section ───────── */
section.scroll-target { scroll-margin-top: 80px; }
.sec-head {
  display: flex; flex-direction: column; gap: 12px;
  margin: clamp(60px, 10vw, 100px) 0 36px;
}
.sec-head .kicker {
  font-size: 13px; color: var(--mint);
  font-weight: 600; letter-spacing: .02em; text-transform: uppercase;
}
.sec-head h2 {
  font-size: clamp(28px, 5vw, 44px);
  font-weight: 800; letter-spacing: -.02em;
  line-height: 1.1;
  max-width: 24ch;
}
.sec-head p {
  font-size: clamp(15px, 2vw, 17px);
  color: var(--text-dim);
  max-width: 64ch;
}

/* ───────── How it works (3 steps) ───────── */
.steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}
.step {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 32px 24px;
  position: relative;
}
.step .n {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: var(--mint); color: #001a14;
  border-radius: 12px;
  font-weight: 800; font-size: 20px;
  margin-bottom: 16px;
}
.step h3 { font-size: 19px; font-weight: 700; margin-bottom: 6px; }
.step p { font-size: 14px; color: var(--text-dim); line-height: 1.6; }

/* ───────── Categories filter ───────── */
.cat-bar {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 24px;
}
.cat-pill {
  padding: 8px 16px; border-radius: 999px;
  background: var(--bg-elev); border: 1px solid var(--line);
  color: var(--text-dim);
  font-size: 14px; font-weight: 500;
  transition: all .15s;
}
.cat-pill:hover { color: var(--text); border-color: #3a3a45; }
.cat-pill.active {
  background: var(--mint); color: #001a14; border-color: var(--mint);
}

/* ───────── Bento grid (templates) ───────── */
.bento {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.tpl {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 18px;
  cursor: pointer;
  transition: all .15s;
  display: flex; flex-direction: column;
  min-height: 130px;
}
.tpl:hover {
  border-color: var(--mint);
  background: var(--bg-card);
  transform: translateY(-2px);
}
.tpl .name {
  font-size: 15px; font-weight: 600;
  margin-bottom: 6px;
  line-height: 1.3;
}
.tpl .desc {
  font-size: 13px; color: var(--text-dim);
  line-height: 1.5;
  flex: 1;
}
.tpl .cat-tag {
  margin-top: 12px;
  font-size: 11px; color: var(--text-mute);
  text-transform: uppercase; letter-spacing: .05em;
}

/* ───────── CTA banner ───────── */
.cta {
  margin: clamp(60px, 10vw, 120px) 0 60px;
  padding: clamp(40px, 8vw, 80px);
  background: linear-gradient(135deg, var(--bg-elev), var(--bg-card));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(600px circle at 50% 0%, rgba(0,212,164,.1), transparent 60%);
  pointer-events: none;
}
.cta h2 {
  font-size: clamp(28px, 5vw, 44px);
  font-weight: 800; letter-spacing: -.02em;
  margin-bottom: 14px;
}
.cta p {
  color: var(--text-dim);
  margin-bottom: 30px;
  font-size: 16px;
}

/* ───────── Footer ───────── */
footer {
  border-top: 1px solid var(--line);
  padding: 36px 0 50px;
  color: var(--text-mute);
  font-size: 13px;
}
.foot-row {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px;
}

/* ───────── App page (Telegram WebApp) ───────── */
body.app {
  padding-bottom: 80px;
  background: var(--tg-bg);
  color: var(--tg-text);
}
.app-head {
  padding: 18px var(--space) 8px;
  display: flex; align-items: center; gap: 12px;
}
.app-head h1 {
  font-size: 22px; font-weight: 800; letter-spacing: -.01em;
}
.app-search {
  margin: 0 var(--space) 14px;
  position: relative;
}
.app-search input {
  width: 100%;
  padding: 14px 18px 14px 44px;
  border-radius: 999px;
  background: var(--bg-elev); border: 1px solid var(--line);
  color: var(--text);
  font-size: 15px;
}
html[dir="rtl"] .app-search input { padding: 14px 44px 14px 18px; }
.app-search input:focus { outline: 2px solid var(--mint); border-color: var(--mint); }
.app-search::before {
  content: '🔍';
  position: absolute; top: 50%; left: 16px; transform: translateY(-50%);
  font-size: 14px; opacity: .7;
}
html[dir="rtl"] .app-search::before { left: auto; right: 16px; }

.app-cats {
  padding: 0 var(--space) 12px;
  display: flex; gap: 8px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.app-cats::-webkit-scrollbar { display: none; }
.app-cat {
  flex: 0 0 auto;
  padding: 7px 14px; border-radius: 999px;
  background: var(--bg-elev); border: 1px solid var(--line);
  font-size: 13px; color: var(--text-dim);
  white-space: nowrap;
  transition: all .12s;
}
.app-cat.active { background: var(--mint); color: #001a14; border-color: var(--mint); font-weight: 600; }

.app-grid {
  padding: 0 var(--space) 20px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
@media (min-width: 600px) { .app-grid { grid-template-columns: repeat(3, 1fr); } }
.app-tpl {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 14px;
  min-height: 100px;
  display: flex; flex-direction: column;
  transition: all .12s;
}
.app-tpl:active { transform: scale(.97); }
.app-tpl .name { font-size: 14px; font-weight: 600; line-height: 1.3; }
.app-tpl .desc {
  font-size: 12px; color: var(--text-dim);
  line-height: 1.4; margin-top: 6px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* Reduced motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ───────── Category palette + emoji watermark ─────────
   Each card gets a subtle gradient tint and a giant emoji watermark
   based on its category. Pure CSS — no images, no extra weight.
*/

:root {
  --cat-ai:        139, 92, 246;     /* electric violet */
  --cat-media:     249, 115, 22;     /* warm orange */
  --cat-tools:     100, 116, 139;    /* cool slate */
  --cat-fun:       245, 158, 11;     /* sun yellow */
  --cat-info:      6, 182, 212;      /* sky cyan */
  --cat-lifestyle: 16, 185, 129;     /* nature green */
  --cat-groups:    236, 72, 153;     /* hot pink */
  --cat-social:    251, 146, 60;     /* warm peach */
  --cat-latam:     239, 68, 68;      /* passion red */

  --cat-default:   100, 116, 139;
}

.tpl, .app-tpl {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

/* Soft tinted gradient + accent border by category */
.tpl[data-cat="ai"],         .app-tpl[data-cat="ai"]         { background: linear-gradient(135deg, rgba(var(--cat-ai),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-ai),.22); }
.tpl[data-cat="media"],      .app-tpl[data-cat="media"]      { background: linear-gradient(135deg, rgba(var(--cat-media),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-media),.22); }
.tpl[data-cat="tools"],      .app-tpl[data-cat="tools"]      { background: linear-gradient(135deg, rgba(var(--cat-tools),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-tools),.22); }
.tpl[data-cat="fun"],        .app-tpl[data-cat="fun"]        { background: linear-gradient(135deg, rgba(var(--cat-fun),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-fun),.22); }
.tpl[data-cat="info"],       .app-tpl[data-cat="info"]       { background: linear-gradient(135deg, rgba(var(--cat-info),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-info),.22); }
.tpl[data-cat="lifestyle"],  .app-tpl[data-cat="lifestyle"]  { background: linear-gradient(135deg, rgba(var(--cat-lifestyle),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-lifestyle),.22); }
.tpl[data-cat="groups"],     .app-tpl[data-cat="groups"]     { background: linear-gradient(135deg, rgba(var(--cat-groups),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-groups),.22); }
.tpl[data-cat="social"],     .app-tpl[data-cat="social"]     { background: linear-gradient(135deg, rgba(var(--cat-social),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-social),.22); }
.tpl[data-cat="latam"],      .app-tpl[data-cat="latam"]      { background: linear-gradient(135deg, rgba(var(--cat-latam),.12), var(--bg-elev) 70%); border-color: rgba(var(--cat-latam),.22); }

/* Emoji watermark — huge, transparent, tucked in corner */
.tpl::before, .app-tpl::before {
  content: attr(data-emoji);
  position: absolute;
  bottom: -8px;
  font-size: 84px;
  line-height: 1;
  opacity: 0.13;
  pointer-events: none;
  z-index: -1;
  filter: blur(0.4px);
}
html[dir="ltr"] .tpl::before, html[dir="ltr"] .app-tpl::before { right: -8px; }
html[dir="rtl"] .tpl::before, html[dir="rtl"] .app-tpl::before { left: -8px; }

/* On hover, watermark pops slightly */
.tpl:hover::before, .app-tpl:active::before { opacity: 0.20; transform: scale(1.06); transition: opacity .2s, transform .2s; }
.tpl:hover, .app-tpl:active { transform: translateY(-2px); }

/* Detail page (template detail) */
body.detail {
  background: var(--bg);
}
.detail-page {
  max-width: 720px; margin: 0 auto;
  padding: 0 var(--space) 120px;
}
.detail-back {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 0;
  color: var(--text-dim); font-size: 14px;
  margin-top: 12px;
}
.detail-back:hover { color: var(--text); opacity: 1; }
.detail-hero {
  position: relative;
  padding: 56px 24px 32px;
  margin: 18px 0 24px;
  border-radius: var(--r-lg);
  text-align: center;
  background: linear-gradient(135deg, rgba(var(--cat-default), 0.18), rgba(var(--cat-default), 0.04) 70%);
  border: 1px solid rgba(var(--cat-default), 0.25);
  overflow: hidden;
}
.detail-hero[data-cat="ai"]         { background: linear-gradient(135deg, rgba(var(--cat-ai), 0.18), rgba(var(--cat-ai), 0.04) 70%); border-color: rgba(var(--cat-ai), 0.30); }
.detail-hero[data-cat="media"]      { background: linear-gradient(135deg, rgba(var(--cat-media), 0.18), rgba(var(--cat-media), 0.04) 70%); border-color: rgba(var(--cat-media), 0.30); }
.detail-hero[data-cat="tools"]      { background: linear-gradient(135deg, rgba(var(--cat-tools), 0.18), rgba(var(--cat-tools), 0.04) 70%); border-color: rgba(var(--cat-tools), 0.30); }
.detail-hero[data-cat="fun"]        { background: linear-gradient(135deg, rgba(var(--cat-fun), 0.18), rgba(var(--cat-fun), 0.04) 70%); border-color: rgba(var(--cat-fun), 0.30); }
.detail-hero[data-cat="info"]       { background: linear-gradient(135deg, rgba(var(--cat-info), 0.18), rgba(var(--cat-info), 0.04) 70%); border-color: rgba(var(--cat-info), 0.30); }
.detail-hero[data-cat="lifestyle"]  { background: linear-gradient(135deg, rgba(var(--cat-lifestyle), 0.18), rgba(var(--cat-lifestyle), 0.04) 70%); border-color: rgba(var(--cat-lifestyle), 0.30); }
.detail-hero[data-cat="groups"]     { background: linear-gradient(135deg, rgba(var(--cat-groups), 0.18), rgba(var(--cat-groups), 0.04) 70%); border-color: rgba(var(--cat-groups), 0.30); }
.detail-hero[data-cat="social"]     { background: linear-gradient(135deg, rgba(var(--cat-social), 0.18), rgba(var(--cat-social), 0.04) 70%); border-color: rgba(var(--cat-social), 0.30); }
.detail-hero[data-cat="latam"]      { background: linear-gradient(135deg, rgba(var(--cat-latam), 0.18), rgba(var(--cat-latam), 0.04) 70%); border-color: rgba(var(--cat-latam), 0.30); }
.detail-hero::after {
  content: attr(data-emoji);
  position: absolute;
  font-size: 280px; line-height: 1;
  opacity: 0.06;
  pointer-events: none;
  z-index: 0;
}
html[dir="ltr"] .detail-hero::after { right: -50px; bottom: -80px; }
html[dir="rtl"] .detail-hero::after { left: -50px; bottom: -80px; }
.detail-hero > * { position: relative; z-index: 1; }
.detail-emoji {
  font-size: 64px; line-height: 1; margin-bottom: 14px;
}
.detail-pill {
  display: inline-block;
  padding: 4px 12px; border-radius: 999px;
  font-size: 12px; letter-spacing: .04em;
  background: rgba(255,255,255,0.08);
  margin-bottom: 14px;
  text-transform: uppercase;
}
.detail-name {
  font-size: clamp(28px, 5vw, 40px);
  font-weight: 800; letter-spacing: -.02em;
  line-height: 1.1;
}
.detail-tagline {
  margin-top: 14px;
  color: var(--text-dim);
  max-width: 50ch; margin-inline: auto;
}

.detail-section {
  margin: 36px 0;
}
.detail-section h2 {
  font-size: 18px; font-weight: 700;
  margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}
.detail-section p {
  color: var(--text-dim); font-size: 15px;
  line-height: 1.65;
}
.feature-list, .usecase-list {
  list-style: none; padding: 0;
  display: grid; gap: 10px;
}
.feature-list li, .usecase-list li {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 14px 16px;
  font-size: 14px;
  display: flex; align-items: flex-start; gap: 10px;
}
.feature-list li::before {
  content: "✓"; color: var(--mint);
  font-weight: 700; flex: 0 0 auto;
}
.usecase-list li::before {
  content: "→"; color: var(--mint);
  flex: 0 0 auto;
}
[dir="rtl"] .usecase-list li::before { content: "←"; }

/* Sticky CTA at bottom */
.detail-sticky {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  padding: 14px var(--space) calc(14px + env(safe-area-inset-bottom));
  background: linear-gradient(to top, var(--bg) 70%, transparent);
  backdrop-filter: blur(10px);
  z-index: 50;
}
.detail-sticky .btn {
  width: 100%;
  max-width: 720px; margin: 0 auto;
  display: flex; align-items: center; justify-content: center;
  padding: 16px 24px;
  font-size: 16px;
}


/* Detail pill — match category color for visual rhythm */
.detail-pill { color: var(--mint); background: rgba(255,255,255,0.06); }
.detail-hero[data-cat="ai"]         .detail-pill { color: rgb(var(--cat-ai));        background: rgba(var(--cat-ai),.10); }
.detail-hero[data-cat="media"]      .detail-pill { color: rgb(var(--cat-media));     background: rgba(var(--cat-media),.10); }
.detail-hero[data-cat="tools"]      .detail-pill { color: #cbd5e1;                   background: rgba(var(--cat-tools),.18); }
.detail-hero[data-cat="fun"]        .detail-pill { color: rgb(var(--cat-fun));       background: rgba(var(--cat-fun),.10); }
.detail-hero[data-cat="info"]       .detail-pill { color: rgb(var(--cat-info));      background: rgba(var(--cat-info),.10); }
.detail-hero[data-cat="lifestyle"]  .detail-pill { color: rgb(var(--cat-lifestyle)); background: rgba(var(--cat-lifestyle),.10); }
.detail-hero[data-cat="groups"]     .detail-pill { color: rgb(var(--cat-groups));    background: rgba(var(--cat-groups),.10); }
.detail-hero[data-cat="social"]     .detail-pill { color: rgb(var(--cat-social));    background: rgba(var(--cat-social),.10); }
.detail-hero[data-cat="latam"]      .detail-pill { color: rgb(var(--cat-latam));     background: rgba(var(--cat-latam),.10); }
