/* Wasla platform UI kit — marketing landing + auth. Mobile-first, RTL-aware. */
* { box-sizing: border-box; }
body { margin: 0; }
.pf { font-family: var(--font-brand); color: var(--text-strong); background: #fff; min-height: 100vh; }
.pf img { max-width: 100%; }
.pf a { color: inherit; text-decoration: none; cursor: pointer; }
.pf-wrap { width: 100%; max-width: 1140px; margin: 0 auto; padding-inline: 20px; }
.pf-btn { font-family: var(--font-ui); font-weight: 600; font-size: .95rem; border-radius: var(--radius-md); padding: .7rem 1.4rem; cursor: pointer; border: 1.5px solid transparent; display: inline-flex; align-items: center; justify-content: center; gap: .5em; transition: background var(--transition-fast), color var(--transition-fast), transform .1s, box-shadow var(--transition-fast); white-space: nowrap; }
.pf-btn:active { transform: translateY(1px); }
.pf-btn--brand { background: var(--brand); color: #fff; }
.pf-btn--brand:hover { background: var(--brand-dark); }
.pf-btn--ghost { background: transparent; color: var(--text-strong); border-color: var(--border-strong); }
.pf-btn--ghost:hover { background: var(--surface-sunken); }
.pf-btn--light { background: #fff; color: var(--slate-900); }
.pf-btn--light:hover { background: var(--slate-100); }
.pf-btn--lg { font-size: 1rem; padding: .85rem 1.7rem; }
.pf-btn--block { width: 100%; }
.eyebrow { font-family: var(--font-ui); font-size: .78rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--brand); }

/* ── Top bar (sticky, switches lang/variant lives in app) ── */
.pf-nav { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.85); backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
.pf-nav__in { display: flex; align-items: center; gap: 16px; height: 62px; }
.pf-brand { display: flex; align-items: center; gap: 9px; }
.pf-brand__mark { width: 30px; height: 30px; }
.pf-brand__wm { font-weight: 800; font-size: 1.2rem; letter-spacing: -.5px; color: var(--brand); }
.pf-brand__ar { font-size: .85rem; font-weight: 700; color: var(--slate-700); }
.pf-nav__links { display: none; gap: 4px; margin-inline: auto; }
.pf-nav__links a { font-family: var(--font-ui); font-size: .9rem; font-weight: 500; color: var(--text-body); padding: .4rem .8rem; border-radius: 7px; }
.pf-nav__links a:hover { color: var(--brand); background: var(--brand-light); }
.pf-nav__right { display: flex; align-items: center; gap: 8px; margin-inline-start: auto; }
.pf-langtog { font-family: var(--font-ui); font-size: .82rem; font-weight: 600; border: 1px solid var(--border-strong); background: #fff; border-radius: 7px; padding: .4rem .7rem; cursor: pointer; color: var(--text-body); display: inline-flex; align-items: center; gap: .4em; }
.pf-langtog:hover { border-color: var(--brand); color: var(--brand); }
.pf-nav__signin { display: none; font-family: var(--font-ui); font-weight: 600; font-size: .9rem; color: var(--text-body); padding: .4rem .6rem; }
.pf-nav__signin:hover { color: var(--brand); }
@media (min-width: 900px) { .pf-nav__links { display: flex; } .pf-nav__signin { display: inline; } }

/* ── Variant switcher (kit affordance) ── */
.pf-variant { position: fixed; bottom: 16px; inset-inline-start: 50%; transform: translateX(-50%); z-index: 80; background: var(--slate-900); color: #fff; border-radius: var(--radius-pill); padding: 6px; display: flex; gap: 4px; box-shadow: var(--shadow-pop); font-family: var(--font-ui); }
[dir="rtl"] .pf-variant { transform: translateX(50%); }
.pf-variant button { border: 0; background: transparent; color: var(--slate-400); font-size: .78rem; font-weight: 600; padding: .4rem .9rem; border-radius: var(--radius-pill); cursor: pointer; }
.pf-variant button.on { background: var(--brand); color: #fff; }
.pf-variant__lbl { font-size: .72rem; color: var(--slate-500); align-self: center; padding-inline: 8px 4px; }

/* ════════ HERO A — light split ════════ */
.heroA { padding: 48px 0 36px; overflow: hidden; }
.heroA__grid { display: grid; gap: 36px; align-items: center; }
.heroA__title { font-size: 2.4rem; font-weight: 800; line-height: 1.1; letter-spacing: -.025em; margin: 14px 0 0; }
.heroA__title .acc { color: var(--brand); }
.heroA__sub { font-size: 1.05rem; color: var(--text-body); line-height: 1.7; margin: 18px 0 0; max-width: 520px; }
.heroA__cta { display: flex; gap: 12px; margin-top: 26px; flex-wrap: wrap; }
.heroA__trust { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 22px; }
.heroA__trust span { font-family: var(--font-ui); font-size: .85rem; color: var(--text-muted); display: flex; align-items: center; gap: .4em; }
.heroA__trust i { color: var(--success); }
@media (min-width: 900px) { .heroA { padding: 72px 0 60px; } .heroA__grid { grid-template-columns: 1.05fr .95fr; gap: 48px; } .heroA__title { font-size: 3.2rem; } }

/* ════════ HERO B — bold slate ════════ */
.heroB { background: linear-gradient(160deg, var(--slate-900), var(--slate-800)); color: #fff; padding: 56px 0 60px; text-align: center; position: relative; overflow: hidden; }
.heroB::before { content: ''; position: absolute; top: -30%; inset-inline-start: 50%; transform: translateX(-50%); width: 700px; height: 700px; background: radial-gradient(circle, rgba(249,115,22,.18), transparent 60%); pointer-events: none; }
.heroB__in { position: relative; }
.heroB .eyebrow { color: var(--orange-400); }
.heroB__title { font-size: 2.5rem; font-weight: 800; line-height: 1.08; letter-spacing: -.025em; margin: 14px 0 0; }
.heroB__title .acc { color: var(--orange-400); }
.heroB__sub { font-size: 1.05rem; color: var(--slate-300); line-height: 1.7; margin: 18px auto 0; max-width: 600px; }
.heroB__cta { display: flex; gap: 12px; margin-top: 28px; justify-content: center; flex-wrap: wrap; }
.heroB__channels { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-top: 36px; }
.heroB__mockwrap { margin-top: 44px; }
@media (min-width: 900px) { .heroB__title { font-size: 3.4rem; } }

/* ── Channel chips ── */
.chan-chip { font-family: var(--font-ui); font-size: .82rem; font-weight: 600; padding: .4rem .9rem; border-radius: var(--radius-pill); background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); color: #fff; display: inline-flex; align-items: center; gap: .5em; }
.chan-chip__dot { width: 8px; height: 8px; border-radius: 50%; }

/* ── Browser mockup (neutral placeholder store preview) ── */
.mock { border-radius: var(--radius-xl); background: #fff; box-shadow: var(--shadow-lg); border: 1px solid var(--border); overflow: hidden; }
.mock--dark { box-shadow: 0 30px 70px rgba(0,0,0,.5); }
.mock__bar { display: flex; align-items: center; gap: 6px; padding: 10px 14px; background: var(--slate-100); border-bottom: 1px solid var(--border); }
.mock__dot { width: 10px; height: 10px; border-radius: 50%; background: var(--slate-300); }
.mock__url { margin-inline-start: 10px; flex: 1; background: #fff; border-radius: var(--radius-pill); font-family: var(--font-ui); font-size: .72rem; color: var(--text-muted); padding: .25rem .7rem; text-align: center; }
.mock__body { padding: 0; }
.mock__hero { background: linear-gradient(135deg, var(--brand), var(--brand-dark)); color: #fff; padding: 22px 18px; text-align: center; }
.mock__hero h4 { font-size: 1rem; font-weight: 800; margin: 0; }
.mock__hero p { font-size: .72rem; opacity: .9; margin: 5px 0 0; }
.mock__tag { display: inline-flex; align-items: center; gap: .35em; background: rgba(255,255,255,.2); border-radius: var(--radius-pill); font-family: var(--font-ui); font-size: .62rem; font-weight: 600; padding: .2rem .6rem; margin-bottom: 8px; }
.mock__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; padding: 16px; }
.mock__card { border: 1px solid var(--border); border-radius: var(--radius-md); overflow: hidden; }
.mock__ph { height: 54px; background: var(--surface-sunken); display: flex; align-items: center; justify-content: center; color: var(--text-subtle); }
.mock__meta { padding: 7px 8px; }
.mock__line { height: 6px; border-radius: 3px; background: var(--slate-200); }
.mock__line.w70 { width: 70%; margin-top: 5px; }
.mock__price { font-family: var(--font-ui); font-size: .68rem; font-weight: 700; color: var(--brand); margin-top: 6px; }

/* ── Section scaffolding ── */
.sec { padding: 56px 0; }
.sec--alt { background: var(--surface-page); }
.sec--dark { background: var(--slate-900); color: #fff; }
.sec__head { text-align: center; max-width: 640px; margin: 0 auto 40px; }
.sec__title { font-size: 1.9rem; font-weight: 800; letter-spacing: -.02em; margin: 8px 0 0; }
.sec__sub { font-size: 1.02rem; color: var(--text-muted); line-height: 1.65; margin: 12px 0 0; }
.sec--dark .sec__sub { color: var(--slate-400); }
@media (min-width: 900px) { .sec { padding: 80px 0; } .sec__title { font-size: 2.3rem; } }

/* ── Stats strip ── */
.stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px 12px; padding: 30px 0; }
.stats__lbl { font-family: var(--font-ui); }
.stats__n { font-size: 2rem; font-weight: 800; letter-spacing: -.02em; color: var(--text-strong); }
.stats__t { font-size: .85rem; color: var(--text-muted); margin-top: 2px; }
.social { text-align: center; font-family: var(--font-ui); font-size: .82rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--text-subtle); }
@media (min-width: 700px) { .stats { grid-template-columns: repeat(4, 1fr); } }

/* ── Features grid ── */
.feat { display: grid; gap: 16px; grid-template-columns: 1fr; }
.feat__card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 24px; transition: box-shadow var(--transition), transform var(--transition); }
.feat__card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.feat__ic { width: 46px; height: 46px; border-radius: var(--radius-lg); background: var(--brand-light); color: var(--brand); display: flex; align-items: center; justify-content: center; font-size: 1.35rem; margin-bottom: 16px; }
.feat__t { font-size: 1.1rem; font-weight: 700; margin: 0 0 6px; }
.feat__d { font-size: .92rem; color: var(--text-muted); line-height: 1.6; margin: 0; }
@media (min-width: 700px) { .feat { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .feat { grid-template-columns: repeat(3, 1fr); } }

/* ── How it works ── */
.how { display: grid; gap: 28px; grid-template-columns: 1fr; counter-reset: step; }
.how__step { text-align: center; position: relative; }
.how__num { width: 52px; height: 52px; border-radius: 50%; background: var(--brand); color: #fff; font-family: var(--font-ui); font-weight: 800; font-size: 1.3rem; display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; box-shadow: 0 6px 18px rgba(var(--brand-rgb), .35); }
.how__t { font-size: 1.15rem; font-weight: 700; margin: 0 0 6px; }
.how__d { font-size: .92rem; color: var(--text-muted); line-height: 1.6; margin: 0 auto; max-width: 280px; }
@media (min-width: 800px) { .how { grid-template-columns: repeat(3, 1fr); gap: 20px; } }

/* ── Pricing ── */
.price { display: grid; gap: 18px; grid-template-columns: 1fr; align-items: stretch; }
.price__card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-2xl); padding: 28px 24px; display: flex; flex-direction: column; position: relative; }
.price__card--pop { border-color: var(--brand); box-shadow: 0 12px 40px rgba(var(--brand-rgb), .15); }
.price__pop { position: absolute; top: -12px; inset-inline-start: 50%; transform: translateX(-50%); background: var(--brand); color: #fff; font-family: var(--font-ui); font-size: .7rem; font-weight: 700; padding: .25rem .8rem; border-radius: var(--radius-pill); white-space: nowrap; }
[dir="rtl"] .price__pop { transform: translateX(50%); }
.price__name { font-size: 1.3rem; font-weight: 800; }
.price__for { font-size: .85rem; color: var(--text-muted); margin-top: 2px; }
.price__limits { list-style: none; padding: 18px 0; margin: 18px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); display: flex; flex-direction: column; gap: 12px; }
.price__limits li { display: flex; align-items: center; gap: 10px; font-size: .92rem; color: var(--text-body); }
.price__limits i { color: var(--success); font-size: 1rem; }
.price__limits b { color: var(--text-strong); font-weight: 700; }
.price__fee { font-family: var(--font-ui); font-size: .85rem; color: var(--text-muted); margin-bottom: 18px; }
.price__fee b { color: var(--brand); font-weight: 700; }
.price__card .pf-btn { margin-top: auto; }
.price__note { text-align: center; font-size: .88rem; color: var(--text-muted); margin-top: 28px; display: flex; align-items: center; justify-content: center; gap: .5em; }
.price__note i { color: var(--success); }
@media (min-width: 900px) { .price { grid-template-columns: repeat(3, 1fr); gap: 20px; } .price__card--pop { transform: scale(1.04); } }

/* ── FAQ ── */
.faq { max-width: 720px; margin: 0 auto; }
.faq__item { border-bottom: 1px solid var(--border); }
.faq__q { width: 100%; background: none; border: 0; text-align: start; font-family: var(--font-brand); font-size: 1.02rem; font-weight: 700; color: var(--text-strong); padding: 20px 0; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.faq__q i { color: var(--brand); transition: transform var(--transition-fast); flex-shrink: 0; }
.faq__item--open .faq__q i { transform: rotate(180deg); }
.faq__a { font-size: .95rem; color: var(--text-muted); line-height: 1.7; padding: 0 0 20px; margin: 0; max-width: 640px; }

/* ── CTA band ── */
.ctaband { background: linear-gradient(135deg, var(--brand), var(--brand-dark)); color: #fff; text-align: center; }
.ctaband h2 { font-size: 1.9rem; font-weight: 800; margin: 0; letter-spacing: -.02em; }
.ctaband p { font-size: 1.05rem; opacity: .92; margin: 12px 0 24px; }
@media (min-width: 900px) { .ctaband h2 { font-size: 2.3rem; } }

/* ── Footer ── */
.pf-foot { background: var(--slate-900); color: var(--slate-400); padding: 48px 0 0; }
.pf-foot__top { display: grid; gap: 28px; grid-template-columns: 1fr; padding-bottom: 32px; }
.pf-foot__brand .pf-brand__wm { color: #fff; }
.pf-foot__tag { font-size: .9rem; line-height: 1.7; margin: 12px 0 0; max-width: 260px; }
.pf-foot__h { color: #f3f4f6; font-family: var(--font-ui); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 700; margin-bottom: 14px; }
.pf-foot__col a { display: block; font-size: .9rem; padding: 5px 0; color: var(--slate-400); }
.pf-foot__col a:hover { color: var(--brand); }
.pf-foot__bar { border-top: 1px solid var(--slate-800); padding: 18px 0; font-size: .82rem; display: flex; flex-wrap: wrap; gap: 8px; justify-content: space-between; align-items: center; }
@media (min-width: 800px) { .pf-foot__top { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 24px; } }

/* ════════ AUTH ════════ */
.auth { min-height: calc(100vh - 62px); display: flex; }
.auth__aside { display: none; flex: 1; background: linear-gradient(160deg, var(--slate-900), var(--slate-800)); color: #fff; padding: 56px; flex-direction: column; justify-content: center; position: relative; overflow: hidden; }
.auth__aside::before { content: ''; position: absolute; bottom: -25%; inset-inline-end: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(249,115,22,.18), transparent 60%); }
.auth__aside-in { position: relative; max-width: 420px; }
.auth__aside h2 { font-size: 1.9rem; font-weight: 800; line-height: 1.2; margin: 20px 0 0; }
.auth__aside p { color: var(--slate-300); line-height: 1.7; margin: 14px 0 0; }
.auth__points { list-style: none; padding: 0; margin: 26px 0 0; display: flex; flex-direction: column; gap: 14px; }
.auth__points li { display: flex; align-items: center; gap: 12px; font-size: .95rem; color: var(--slate-200); }
.auth__points i { color: var(--orange-400); font-size: 1.1rem; }
.auth__main { flex: 1; display: flex; align-items: center; justify-content: center; padding: 32px 20px; background: var(--surface-page); }
.auth__card { width: 100%; max-width: 440px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-2xl); box-shadow: var(--shadow-md); padding: 32px; }
.auth__brand { display: flex; align-items: center; gap: 9px; margin-bottom: 22px; }
.auth__title { font-size: 1.5rem; font-weight: 800; letter-spacing: -.02em; margin: 0; }
.auth__sub { font-size: .92rem; color: var(--text-muted); margin: 4px 0 0; }
.auth__sect { font-family: var(--font-ui); font-size: .72rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--text-subtle); margin: 24px 0 12px; }
.fld { margin-bottom: 16px; }
.fld__l { display: block; font-family: var(--font-ui); font-size: .82rem; font-weight: 600; color: var(--text-body); margin-bottom: 6px; }
.fld__in { width: 100%; border: 1.5px solid var(--border); border-radius: var(--radius-md); font-family: var(--font-brand); font-size: .95rem; color: var(--text-strong); padding: .65rem .8rem; background: #fff; }
.fld__in:focus { outline: none; border-color: var(--brand); box-shadow: var(--ring-brand); }
.fld__in::placeholder { color: var(--text-subtle); }
.fld__hint { font-family: var(--font-ui); font-size: .75rem; color: var(--text-muted); margin-top: 5px; }
.fld__grp { display: flex; align-items: stretch; }
.fld__grp .fld__in { border-start-end-radius: 0; border-end-end-radius: 0; }
.fld__addon { display: flex; align-items: center; padding: 0 .8rem; background: var(--surface-sunken); border: 1.5px solid var(--border); border-inline-start: 0; border-start-end-radius: var(--radius-md); border-end-end-radius: var(--radius-md); font-family: var(--font-mono); font-size: .82rem; color: var(--text-muted); white-space: nowrap; }
.fld2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.auth__row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; gap: 10px; }
.auth__check { display: flex; align-items: center; gap: 7px; font-family: var(--font-ui); font-size: .85rem; color: var(--text-body); cursor: pointer; }
.auth__check input { width: 16px; height: 16px; accent-color: var(--brand); }
.auth__link { font-family: var(--font-ui); font-size: .85rem; font-weight: 600; color: var(--brand); }
.auth__foot { text-align: center; font-family: var(--font-ui); font-size: .88rem; color: var(--text-muted); margin-top: 20px; }
.auth__foot a { font-weight: 700; color: var(--brand); }
@media (min-width: 900px) { .auth__aside { display: flex; } }
