/* ============================================
   FlowNile — SHARED STYLES (all pages use this)
   Edit colors/fonts here once → applies everywhere.
   ============================================ */
:root{
  --bg:#070710; --bg-2:#0c0c18; --panel:#11111f; --panel-2:#161627;
  --border:#23233a; --text:#eaeaf2; --muted:#8b8ba3;
  --brand:#7c5cff; --brand-2:#9d8aff; --cyan:#2ee6c5; --glow:rgba(124,92,255,.5);
  --radius:18px; --maxw:1180px;
  --font-display:'Sora',sans-serif; --font-body:'Space Grotesk',sans-serif;
}
html[dir="rtl"]{ --font-display:'Cairo',sans-serif; --font-body:'Cairo',sans-serif; }
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;z-index:-2;background:radial-gradient(700px circle at 15% 5%,rgba(124,92,255,.16),transparent 45%),radial-gradient(600px circle at 85% 20%,rgba(46,230,197,.10),transparent 45%),var(--bg)}
body::after{content:'';position:fixed;inset:0;z-index:-1;opacity:.4;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:54px 54px;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 75%);mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 75%)}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* NAV */
nav{position:sticky;top:0;z-index:100;backdrop-filter:blur(14px);background:rgba(7,7,16,.7);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:800;font-size:20px;letter-spacing:-.5px}
.logo-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--brand),var(--cyan));display:grid;place-items:center;box-shadow:0 0 22px var(--glow)}
.logo-mark svg{width:22px;height:22px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--muted);font-size:14.5px;font-weight:500;transition:color .2s;position:relative}
.nav-links a:hover{color:var(--text)}
.nav-links a::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:2px;background:var(--brand);transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:12px}
.btn{font-family:var(--font-body);font-weight:600;font-size:14.5px;padding:11px 22px;border-radius:11px;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex;align-items:center;gap:8px}
.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;box-shadow:0 6px 22px var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--glow)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--brand);background:rgba(124,92,255,.08)}
.btn-lg{padding:15px 30px;font-size:16px;border-radius:13px}
.lang-toggle{background:var(--panel);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:10px;cursor:pointer;font-family:var(--font-body);font-weight:600;font-size:13px;transition:all .2s}
.lang-toggle:hover{border-color:var(--brand)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px}
.burger span{width:24px;height:2px;background:var(--text);border-radius:2px}

/* PAGE HERO */
.page-hero{padding:80px 0 50px;text-align:center}
.page-hero .sec-tag{color:var(--brand-2);font-weight:700;font-size:14px;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px}
.page-hero h1{font-family:var(--font-display);font-weight:800;font-size:clamp(34px,5vw,56px);letter-spacing:-1.5px;line-height:1.08;margin-bottom:18px;max-width:850px;margin-left:auto;margin-right:auto}
.page-hero p{color:var(--muted);font-size:18px;max-width:600px;margin:0 auto}
.grad{background:linear-gradient(120deg,var(--brand-2),var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* SECTIONS */
section.block{padding:70px 0}
section.block.alt{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.sec-head{text-align:center;max-width:680px;margin:0 auto 54px}
.sec-tag{color:var(--brand-2);font-weight:700;font-size:14px;letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
.sec-head h2{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,4vw,42px);letter-spacing:-1px;margin-bottom:16px}
.sec-head p{color:var(--muted);font-size:17px}

/* SERVICES system rows */
.sys-row{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.sys-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.3);color:var(--brand-2);padding:7px 15px;border-radius:100px;font-size:13px;font-weight:700;margin-bottom:18px}
.sys-text h2{font-family:var(--font-display);font-weight:800;font-size:clamp(26px,3.5vw,38px);letter-spacing:-1px;margin-bottom:16px}
.sys-text p{color:var(--muted);font-size:16px;margin-bottom:22px}
.sys-list{list-style:none;margin-bottom:26px}
.sys-list li{position:relative;padding-left:30px;margin-bottom:12px;font-size:15px;color:#c7c7d6}
.sys-list li::before{content:'✓';position:absolute;left:0;color:var(--cyan);font-weight:800}
html[dir="rtl"] .sys-list li{padding-left:0;padding-right:30px}
html[dir="rtl"] .sys-list li::before{left:auto;right:0}
.sys-visual{display:flex;justify-content:center}
.vis-chat{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:20px;padding:22px;width:100%;max-width:380px;box-shadow:0 24px 60px rgba(0,0,0,.4)}
.vc-bubble{max-width:82%;padding:11px 15px;border-radius:15px;font-size:14px;margin-bottom:10px}
.vc-bubble.in{background:var(--panel-2);border-bottom-left-radius:4px}
.vc-bubble.out{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;margin-left:auto;border-bottom-right-radius:4px}
html[dir="rtl"] .vc-bubble.out{margin-left:0;margin-right:auto}
.vis-card{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:20px;padding:26px;width:100%;max-width:380px;box-shadow:0 24px 60px rgba(0,0,0,.4)}
.vis-card-row{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:15px;margin-bottom:10px}
.vis-card-line{font-size:14px;color:var(--text);padding:3px 0}
.vis-card-line.muted{color:var(--muted);font-size:13px}
.vis-pill{background:rgba(46,230,197,.14);color:var(--cyan);font-size:12px;font-weight:700;padding:5px 12px;border-radius:8px}
.vis-pill.green{background:rgba(74,222,128,.15);color:#4ade80}
.vis-stat-n{font-family:var(--font-display);font-weight:800;font-size:32px;color:var(--brand-2)}
.vis-stat-l{font-size:12px;color:var(--muted)}
@media(min-width:861px){.sys-row.reverse .sys-text{order:2}.sys-row.reverse .sys-visual{order:1}}

/* SERVICE cards (home) */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}
.svc-card{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:transform .3s,border-color .3s,box-shadow .3s;position:relative;overflow:hidden}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand),var(--cyan));transform:scaleX(0);transition:transform .3s;transform-origin:left}
.svc-card:hover{transform:translateY(-6px);border-color:var(--brand);box-shadow:0 20px 50px rgba(124,92,255,.18)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon{width:54px;height:54px;border-radius:14px;background:rgba(124,92,255,.12);display:grid;place-items:center;margin-bottom:18px;font-size:26px}
.svc-card h3{font-family:var(--font-display);font-weight:700;font-size:19px;margin-bottom:10px}
.svc-card p{color:var(--muted);font-size:14.5px}

/* PRICING */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;align-items:stretch}
.price-card{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:20px;padding:32px 26px;display:flex;flex-direction:column;position:relative;transition:transform .3s}
.price-card:hover{transform:translateY(-6px)}
.price-card.featured{border-color:var(--brand);box-shadow:0 20px 60px rgba(124,92,255,.22)}
.price-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-size:12px;font-weight:700;padding:6px 16px;border-radius:100px;box-shadow:0 6px 16px var(--glow);white-space:nowrap}
.price-card h3{font-family:var(--font-display);font-weight:700;font-size:21px;margin-bottom:8px}
.price-card .price{font-family:var(--font-display);font-weight:800;font-size:42px;margin:10px 0 4px;letter-spacing:-1px}
.price-card .price span{font-size:15px;color:var(--muted);font-weight:500}
.price-card .pdesc{color:var(--muted);font-size:14px;margin-bottom:22px;min-height:42px}
.price-card ul{list-style:none;margin-bottom:26px;flex:1}
.price-card li{display:flex;align-items:center;gap:10px;font-size:14px;padding:7px 0;color:#c7c7d6}
.price-card li svg{width:17px;height:17px;color:var(--cyan);flex-shrink:0}
.price-card .btn{width:100%;justify-content:center}

/* FAQ */
.faq{max-width:760px;margin:0 auto}
.faq-item{background:var(--panel);border:1px solid var(--border);border-radius:14px;margin-bottom:14px;overflow:hidden}
.faq-q{padding:20px 24px;font-weight:600;font-size:16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q::after{content:'+';font-size:24px;color:var(--brand-2);transition:transform .3s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s,padding .35s;color:var(--muted);font-size:15px;padding:0 24px}
.faq-item.open .faq-a{max-height:240px;padding:0 24px 20px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-top:10px}
.value-card{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:var(--radius);padding:28px;text-align:center;transition:transform .3s,border-color .3s}
.value-card:hover{transform:translateY(-5px);border-color:var(--brand)}
.value-card .vicon{font-size:34px;margin-bottom:14px}
.value-card h3{font-family:var(--font-display);font-weight:700;font-size:18px;margin-bottom:8px}
.value-card p{color:var(--muted);font-size:14px}
.story{max-width:760px;margin:0 auto;text-align:center}
.story p{color:var(--muted);font-size:17px;margin-bottom:18px;line-height:1.8}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.form-card{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--border);border-radius:20px;padding:32px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:14px;font-weight:600;margin-bottom:8px;color:#c7c7d6}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:11px;padding:13px 15px;color:var(--text);font-family:var(--font-body);font-size:15px;transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--brand)}
.form-group textarea{resize:vertical;min-height:100px}
.contact-side .info-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:18px}
.contact-side .info-card h4{font-family:var(--font-display);font-weight:700;font-size:16px;margin-bottom:14px}
.contact-side .info-row{display:flex;align-items:center;gap:12px;padding:10px 0;color:var(--muted);font-size:14.5px}
.contact-side .info-row .ic{width:38px;height:38px;border-radius:10px;background:rgba(124,92,255,.12);display:grid;place-items:center;font-size:18px;flex-shrink:0}
.form-msg{padding:14px;border-radius:11px;margin-bottom:18px;font-size:14px;display:none}
.form-msg.ok{background:rgba(74,222,128,.12);border:1px solid rgba(74,222,128,.3);color:#4ade80;display:block}
.form-msg.err{background:rgba(255,107,107,.12);border:1px solid rgba(255,107,107,.3);color:#ff6b6b;display:block}

/* CTA strip */
.cta-strip{background:linear-gradient(135deg,rgba(124,92,255,.16),rgba(46,230,197,.1));border:1px solid var(--border);border-radius:26px;padding:54px;text-align:center;margin:40px 0}
.cta-strip h2{font-family:var(--font-display);font-weight:800;font-size:clamp(26px,3.5vw,38px);margin-bottom:14px;letter-spacing:-1px}
.cta-strip p{color:var(--muted);font-size:17px;margin-bottom:28px;max-width:520px;margin-left:auto;margin-right:auto}

/* FOOTER */
footer{border-top:1px solid var(--border);padding:50px 0 30px;margin-top:40px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:36px}
.foot-brand p{color:var(--muted);font-size:14px;margin-top:14px;max-width:300px}
.foot-col h5{font-family:var(--font-display);font-weight:700;font-size:14px;margin-bottom:16px;letter-spacing:.5px}
.foot-col a{display:block;color:var(--muted);font-size:14px;padding:6px 0;transition:color .2s}
.foot-col a:hover{color:var(--brand-2)}
.foot-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:13px;flex-wrap:wrap;gap:12px}

/* WhatsApp float */
.wa-float{position:fixed;bottom:26px;right:26px;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 8px 28px rgba(37,211,102,.5);z-index:90;transition:transform .2s;cursor:pointer}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:32px;height:32px;fill:#fff}
html[dir="rtl"] .wa-float{right:auto;left:26px}

/* chat widget */
.cw-toggle{position:fixed;bottom:26px;right:98px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--cyan));display:grid;place-items:center;box-shadow:0 8px 28px var(--glow);z-index:90;cursor:pointer;transition:transform .2s}
.cw-toggle:hover{transform:scale(1.1)}
.cw-toggle svg{width:30px;height:30px}
html[dir="rtl"] .cw-toggle{right:auto;left:98px}
.cw-panel{position:fixed;bottom:100px;right:26px;width:350px;max-width:calc(100vw - 40px);height:480px;max-height:70vh;background:var(--bg-2);border:1px solid var(--border);border-radius:20px;box-shadow:0 30px 80px rgba(0,0,0,.6);z-index:95;display:none;flex-direction:column;overflow:hidden}
html[dir="rtl"] .cw-panel{right:auto;left:26px}
.cw-panel.open{display:flex;animation:cwUp .3s}
@keyframes cwUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.cw-head{background:linear-gradient(135deg,var(--brand),var(--brand-2));padding:16px 18px;display:flex;align-items:center;gap:12px}
.cw-head .cw-av{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.2);display:grid;place-items:center}
.cw-head .cw-av svg{width:22px;height:22px}
.cw-head h4{font-family:var(--font-display);font-size:15px;color:#fff}
.cw-head .cw-st{font-size:12px;color:rgba(255,255,255,.85)}
.cw-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px}
.cw-msg{max-width:82%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5}
.cw-msg.bot{background:var(--panel-2);align-self:flex-start;border-bottom-left-radius:4px}
.cw-msg.user{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.cw-foot{padding:14px;border-top:1px solid var(--border);display:flex;gap:10px}
.cw-foot input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:11px;padding:11px 14px;color:var(--text);font-family:var(--font-body);font-size:14px}
.cw-foot input:focus{outline:none;border-color:var(--brand)}
.cw-foot button{background:linear-gradient(135deg,var(--brand),var(--brand-2));border:none;border-radius:11px;width:44px;display:grid;place-items:center;cursor:pointer}
.cw-foot button svg{width:20px;height:20px;fill:#fff}
.cw-typing{font-size:13px;color:var(--muted);padding:0 18px 8px}

/* reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.reveal.show{opacity:1;transform:translateY(0)}

/* lang helpers */
[data-ar]{display:none}
html[dir="rtl"] [data-en]{display:none}
html[dir="rtl"] [data-ar]{display:inline}
html[dir="rtl"] .page-hero p,html[dir="rtl"] .sec-head p{text-align:center}

/* responsive */
@media(max-width:860px){
  .nav-links{display:none;position:absolute;top:72px;left:0;right:0;background:var(--bg-2);flex-direction:column;padding:20px;border-bottom:1px solid var(--border);gap:8px}
  .burger{display:flex}
  .sys-row{grid-template-columns:1fr;gap:34px}
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .foot-grid{grid-template-columns:1fr;gap:28px}
  .nav-cta .btn-primary{display:none}
}

/* ===== HOMEPAGE HERO + SHOWCASE FIX ===== */
.hero{position:relative;padding:140px 0 90px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:8px;padding:7px 15px;border:1px solid rgba(124,92,255,.35);background:rgba(124,92,255,.08);border-radius:100px;font-size:13px;color:#c9c2ff;margin-bottom:22px}
.badge .dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 10px #22c55e;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{font-family:'Sora',sans-serif;font-size:clamp(34px,5vw,60px);line-height:1.08;font-weight:800;margin:0 0 22px;letter-spacing:-1.5px}
.hero .sub{font-size:clamp(16px,2vw,19px);color:#a9a6c0;line-height:1.6;max-width:560px;margin:0 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:46px}
.hero-stats{display:flex;gap:42px;flex-wrap:wrap}
.stat .n{font-family:'Sora',sans-serif;font-size:30px;font-weight:800;color:#fff;line-height:1}
.stat .l{font-size:14px;color:#8e8ba6;margin-top:6px}

/* hero chat visual */
.chat-mock{background:linear-gradient(180deg,#15131f,#0f0e17);border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:18px;box-shadow:0 30px 70px rgba(0,0,0,.5);max-width:400px;margin-left:auto}
.chat-head{display:flex;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:16px}
.chat-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#7c5cff,#4ad9c4);display:grid;place-items:center;flex:none}
.chat-avatar svg{width:24px;height:24px}
.chat-name{font-weight:700;font-size:15px;color:#fff}
.chat-status{font-size:12px;color:#22c55e}
.bubble{max-width:80%;padding:11px 15px;border-radius:16px;font-size:14px;line-height:1.45;margin-bottom:10px}
.bubble.in{background:#26233a;color:#e8e6f5;border-bottom-left-radius:5px;margin-right:auto}
.bubble.out{background:linear-gradient(135deg,#7c5cff,#6b4fe0);color:#fff;border-bottom-right-radius:5px;margin-left:auto}

/* showcase section */
.showcase{padding:90px 0}
.show-card{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.07);border-radius:24px;padding:40px;margin-bottom:26px}
.show-card:nth-child(even) .show-vis{order:2}
.show-body h3{font-family:'Sora',sans-serif;font-size:24px;margin:0 0 10px;color:#fff}
.show-body .pdesc{color:#a9a6c0;line-height:1.6;font-size:16px}
.show-vis{background:#0f0e17;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:18px}
.mini-bubble{max-width:85%;padding:9px 13px;border-radius:13px;font-size:13px;line-height:1.4;margin-bottom:8px}
.mini-bubble.in{background:#26233a;color:#e8e6f5;border-bottom-left-radius:4px;margin-right:auto}
.mini-bubble.out{background:linear-gradient(135deg,#7c5cff,#6b4fe0);color:#fff;border-bottom-right-radius:4px;margin-left:auto}
.tag-float{display:inline-block;background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.3);color:#c9c2ff;padding:5px 12px;border-radius:100px;font-size:12px;font-weight:600;margin-bottom:14px}
.block .n{font-family:'Sora',sans-serif;font-size:34px;font-weight:800;display:inline-block;margin-right:8px}
.block .l{font-size:13px;color:#8e8ba6;display:block;margin-top:4px}
.price{font-family:'Sora',sans-serif;font-weight:800;color:#fff}

/* mobile */
@media(max-width:860px){
  .hero-grid,.show-card{grid-template-columns:1fr}
  .hero{padding:110px 0 60px}
  .chat-mock{margin:30px auto 0}
  .show-card:nth-child(even) .show-vis{order:0}
  .hero-stats{gap:28px}
}
