/* ============================================================
   PINK TAXI EGYPT — Design System
   Colors extracted from the official Pink Taxi logo
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  /* Brand pinks (sampled from logo) */
  --pink-900:#9E0561;
  --pink-700:#C8077C;
  --pink-600:#DC0B86;
  --pink:#EC0D8C;        /* primary */
  --pink-500:#ED2092;
  --pink-400:#F25CA8;
  --pink-300:#F58BC0;
  --pink-200:#F9B8D6;
  --pink-100:#FBD7E9;
  --pink-50:#FDEFF6;
  --pink-25:#FEF7FB;
  --grad:linear-gradient(118deg,#ED2092 0%,#EC0D8C 45%,#F06AAB 100%);
  --grad-soft:linear-gradient(135deg,#FDEFF6 0%,#FBD7E9 100%);

  /* Ink (from glossy TAXI lettering) */
  --ink:#17121A;
  --ink-800:#241E29;
  --ink-700:#3A3340;
  --muted:#736B79;
  --muted-2:#9A93A0;
  --line:#ECE4EC;
  --line-2:#F4EEF4;

  --bg:#FFFFFF;
  --bg-soft:#FCF8FB;
  --bg-ink:#17121A;

  --shadow-sm:0 2px 10px rgba(23,18,26,.05);
  --shadow:0 14px 40px -18px rgba(213,11,128,.28), 0 6px 16px -10px rgba(23,18,26,.08);
  --shadow-lg:0 40px 90px -40px rgba(213,11,128,.45), 0 12px 30px -18px rgba(23,18,26,.14);
  --shadow-ink:0 30px 70px -30px rgba(23,18,26,.55);

  --r-xl:30px; --r-lg:22px; --r-md:16px; --r-sm:12px; --r-pill:999px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:'Manrope',system-ui,sans-serif;
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility; overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',system-ui,sans-serif; font-weight:700; line-height:1.04; margin:0; letter-spacing:-.018em;}
p{margin:0}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
ul{margin:0; padding:0; list-style:none}
::selection{background:var(--pink-200); color:var(--ink)}

.wrap{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 26px}
.sec{padding:96px 0}
.sec-sm{padding:64px 0}
@media(max-width:760px){.sec{padding:64px 0}.sec-sm{padding:48px 0}}

/* ---------- Type scale ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Manrope'; font-weight:700; font-size:12.5px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--pink); 
}
.eyebrow::before{content:""; width:22px; height:2px; background:var(--pink); border-radius:2px}
.eyebrow.center::after{content:""; width:22px; height:2px; background:var(--pink); border-radius:2px}
.eyebrow.on-ink{color:var(--pink-300)}
.eyebrow.on-ink::before,.eyebrow.on-ink.center::after{background:var(--pink-300)}

.h-display{font-size:clamp(40px,7vw,76px); letter-spacing:-.03em; line-height:.98}
.h1{font-size:clamp(34px,5vw,56px)}
.h2{font-size:clamp(28px,3.6vw,44px)}
.h3{font-size:clamp(21px,2.2vw,27px)}
.lead{font-size:clamp(17px,1.5vw,20px); color:var(--muted); line-height:1.62; font-weight:500}
.subtle{color:var(--muted)}
.mono-num{font-variant-numeric:tabular-nums}
.grad-text{background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:'Manrope'; font-weight:700; font-size:15.5px; line-height:1;
  padding:16px 26px; border-radius:var(--r-pill); cursor:pointer; border:1.6px solid transparent;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .2s, color .2s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--pink); color:#fff; box-shadow:0 12px 26px -12px rgba(236,13,140,.7)}
.btn-primary:hover{background:var(--pink-700); transform:translateY(-2px); box-shadow:0 18px 34px -12px rgba(236,13,140,.75)}
.btn-grad{background:var(--grad); color:#fff; box-shadow:0 14px 30px -12px rgba(236,13,140,.6); background-size:160% 160%}
.btn-grad:hover{transform:translateY(-2px); background-position:100% 0}
.btn-ink{background:var(--ink); color:#fff}
.btn-ink:hover{background:#000; transform:translateY(-2px)}
.btn-ghost{background:#fff; color:var(--ink); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--pink-300); color:var(--pink-700); transform:translateY(-2px)}
.btn-outline-light{background:transparent; color:#fff; border-color:rgba(255,255,255,.32)}
.btn-outline-light:hover{background:rgba(255,255,255,.1); border-color:#fff}
.btn-white{background:#fff; color:var(--pink-700)}
.btn-white:hover{transform:translateY(-2px); box-shadow:var(--shadow-lg)}
.btn-lg{padding:18px 32px; font-size:16.5px}
.btn-sm{padding:12px 18px; font-size:14px}
.btn-block{width:100%}

/* App store buttons */
.store-row{display:flex; gap:12px; flex-wrap:wrap}
.store-btn{
  display:inline-flex; align-items:center; gap:11px; padding:11px 18px;
  background:var(--ink); color:#fff; border-radius:14px; transition:transform .25s var(--ease), box-shadow .25s;
}
.store-btn:hover{transform:translateY(-2px); box-shadow:var(--shadow-ink)}
.store-btn svg{width:26px;height:26px;flex:none}
.store-btn > span{display:flex; flex-direction:column; align-items:flex-start; gap:2px; min-width:0}
.store-btn .sb-sm,.store-btn .sb-lg{display:block}
.store-btn .sb-sm{font-size:10.5px; letter-spacing:.04em; opacity:.8; line-height:1.1}
.store-btn .sb-lg{font-family:'Bricolage Grotesque'; font-weight:600; font-size:17px; line-height:1.1}
.store-btn.on-light{background:#fff; color:var(--ink); border:1.5px solid var(--line)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky; top:0; z-index:80; transition:all .3s var(--ease)}
.nav{
  display:flex; align-items:center; justify-content:flex-start; gap:12px;
  height:74px; margin:0 auto; max-width:1440px; padding:0 20px;
}
.nav-wrap{background:rgba(255,255,255,.82); backdrop-filter:blur(16px) saturate(1.4); border-bottom:1px solid var(--line-2); transition:all .3s var(--ease)}
.site-header.scrolled .nav-wrap{box-shadow:var(--shadow-sm); border-bottom-color:var(--line)}
.brand{display:flex; align-items:center; gap:0; line-height:0; font-family:'Bricolage Grotesque'; font-weight:700; flex:none; flex-shrink:0; overflow:visible}
.brand img{display:block; width:112px; height:auto; max-width:none; flex:none; flex-shrink:0}
.brand .bt{font-size:19px; letter-spacing:-.02em; line-height:1}
.brand .bt small{display:block; font-family:'Manrope'; font-weight:600; font-size:9.5px; letter-spacing:.22em; color:var(--pink); text-transform:uppercase; margin-top:2px}
.nav-links{display:flex; align-items:center; justify-content:center; gap:0; min-width:0; flex:1 1 auto; flex-wrap:nowrap}
.nav-links a{
  display:inline-flex; align-items:center;
  font-weight:600; font-size:13px; line-height:1; color:var(--ink-700); padding:8px 9px; border-radius:10px;
  transition:color .2s, background .2s; position:relative; white-space:nowrap !important; word-break:keep-all; overflow-wrap:normal; flex:none;
}
.nav-links a span{white-space:nowrap !important; word-break:keep-all; overflow-wrap:normal}
.nav-links a:hover{color:var(--pink); background:var(--pink-25)}
.nav-links a.active{color:var(--pink)}
.nav-cta{display:flex; align-items:center; gap:10px; margin-inline-start:auto; flex:none; flex-shrink:0}
.nav-toggle{display:none; width:46px; height:46px; border:1.5px solid var(--line); background:#fff; border-radius:12px; cursor:pointer; align-items:center; justify-content:center; pointer-events:auto; position:relative; z-index:82; touch-action:manipulation; -webkit-tap-highlight-color:transparent; -webkit-appearance:none; appearance:none}
.nav-toggle span{display:block; width:20px; height:2px; background:var(--ink); border-radius:2px; position:relative; transition:.25s}
.nav-toggle span::before,.nav-toggle span::after{content:""; position:absolute; left:0; width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.25s}
.nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}

@media(max-width:1599px){
  .nav-cta .btn-ghost{display:none}
}
@media(max-width:1199px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:flex}
  .mobile-menu{display:block}
  .nav{height:74px; padding:0 18px; gap:12px; min-width:0}
  .nav-cta{gap:8px; margin-inline-start:auto; flex-shrink:0}
  .brand img{width:92px; height:auto}
  .lang-btn{padding:8px 12px; font-size:12.5px}
}
@media(max-width:980px){
  .nav{height:70px; padding:0 18px; gap:12px; min-width:0}
  .nav-cta{gap:8px; margin-inline-start:auto; flex-shrink:0}
  .brand img{width:92px; height:auto}
  .lang-btn{padding:8px 12px; font-size:12.5px}
}
.mobile-menu{
  display:none; position:fixed; inset:74px 0 0 0; z-index:79; background:#fff;
  padding:18px 26px 40px; transform:translateY(-12px); opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .3s var(--ease), transform .3s var(--ease); overflow-y:auto;
  overscroll-behavior:contain; -webkit-overflow-scrolling:touch;
}
.mobile-menu.open,
.mobile-menu.is-open,
[data-mobile-menu].open,
[data-mobile-menu].is-open{
  display:block; visibility:visible; opacity:1; transform:none; pointer-events:auto; z-index:81;
}
.mobile-menu[hidden],
[data-mobile-menu][hidden]{display:none !important; visibility:hidden !important; opacity:0 !important; pointer-events:none !important}
.mobile-menu a{display:block; font-family:'Bricolage Grotesque'; font-weight:600; font-size:25px; padding:14px 0; border-bottom:1px solid var(--line-2); color:var(--ink)}
.mobile-menu a:hover{color:var(--pink)}
.mobile-menu .mm-cta{margin-top:24px; display:grid; gap:12px}
body.menu-open{overflow:hidden}
@media(max-width:980px){
  .mobile-menu{inset:70px 0 0 0; padding:16px 18px 32px}
  .mobile-menu a{font-size:20px; padding:15px 0}
  .mobile-menu .mm-cta .btn{min-height:50px}
}

/* ---------- Cards & chips ---------- */
.card{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .3s}
.card.hov:hover{transform:translateY(-5px); box-shadow:var(--shadow); border-color:var(--pink-100)}
.chip{display:inline-flex; align-items:center; gap:7px; padding:7px 13px; border-radius:var(--r-pill); font-size:13px; font-weight:700; background:var(--pink-50); color:var(--pink-700)}
.chip.ink{background:rgba(255,255,255,.1); color:#fff; backdrop-filter:blur(4px)}
.chip.outline{background:#fff; border:1.4px solid var(--line); color:var(--ink-700)}
.tag{display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--pink); }

.icon-badge{width:54px; height:54px; border-radius:15px; display:grid; place-items:center; background:var(--grad-soft); color:var(--pink-700); flex:none}
.icon-badge svg{width:26px; height:26px}
.icon-badge.solid{background:var(--grad); color:#fff}
.icon-badge.ink{background:var(--ink); color:#fff}

/* feature/list checks */
.ck{display:flex; gap:12px; align-items:flex-start; margin:0 0 14px}
.ck:last-child{margin-bottom:0}
.ck .ico{flex:none; width:24px; height:24px; border-radius:50%; background:var(--pink-50); color:var(--pink); display:grid; place-items:center; margin-top:1px}
.ck .ico svg{width:14px; height:14px}
.ck b{font-weight:700}
.ck span{color:var(--muted); font-weight:500}

/* ---------- Forms ---------- */
.field{margin-bottom:16px}
.field label{display:block; font-size:13.5px; font-weight:700; margin-bottom:7px; color:var(--ink-700)}
.field label .req{color:var(--pink)}
.input,.select,.textarea{
  width:100%; font-family:'Manrope'; font-size:15.5px; color:var(--ink); background:#fff;
  border:1.5px solid var(--line); border-radius:var(--r-sm); padding:14px 15px; transition:border-color .2s, box-shadow .2s;
}
.input::placeholder,.textarea::placeholder{color:var(--muted-2)}
.input:focus,.select:focus,.textarea:focus{outline:none; border-color:var(--pink-300); box-shadow:0 0 0 4px var(--pink-50)}
.textarea{resize:vertical; min-height:110px}
.select{appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%23736B79' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M5 8l5 5 5-5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:42px; cursor:pointer}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:0 16px}
.form-grid .full{grid-column:1/-1}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}
.form-note{font-size:12.5px; color:var(--muted-2); margin-top:6px}

/* radio pills */
.pills{display:flex; flex-wrap:wrap; gap:9px}
.pill-opt{position:relative}
.pill-opt input{position:absolute; opacity:0; pointer-events:none}
.pill-opt label{
  display:inline-flex; align-items:center; gap:7px; padding:11px 16px; border-radius:var(--r-pill);
  border:1.5px solid var(--line); font-weight:600; font-size:14px; cursor:pointer; transition:.2s; color:var(--ink-700);
}
.pill-opt input:checked + label{background:var(--pink-50); border-color:var(--pink); color:var(--pink-700)}
.pill-opt label:hover{border-color:var(--pink-300)}

/* success state */
.form-success{display:none; text-align:center; padding:34px 20px}
.form-success.show{display:block; animation:pop .5s var(--ease)}
.form-success .fs-ico{width:66px;height:66px; border-radius:50%; background:var(--grad); color:#fff; display:grid; place-items:center; margin:0 auto 16px}
.form-success .fs-ico svg{width:32px;height:32px}
@keyframes pop{from{transform:scale(.9); opacity:0}to{transform:none; opacity:1}}

/* ---------- Section header ---------- */
.sec-head{max-width:680px}
.sec-head.center{margin:0 auto; text-align:center}
.sec-head .eyebrow{margin-bottom:16px}
.sec-head .lead{margin-top:18px}

/* ---------- Footer ---------- */
.footer{background:var(--ink); color:#fff; padding:72px 0 30px}
.footer a{color:rgba(255,255,255,.7); transition:color .2s}
.footer a:hover{color:#fff}
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px}
.footer h5{font-family:'Manrope'; font-weight:700; font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--pink-300); margin:0 0 18px}
.footer li{margin-bottom:11px; font-size:14.5px}
.footer .f-logo{display:inline-flex; align-items:center; gap:10px; background:#fff; padding:10px 14px; border-radius:14px; margin-bottom:18px}
.footer .f-logo img{height:34px}
.footer .f-desc{color:rgba(255,255,255,.62); font-size:14.5px; max-width:300px; line-height:1.6}
.f-social{display:flex; gap:10px; margin-top:20px}
.f-social a{width:42px;height:42px; border-radius:12px; background:rgba(255,255,255,.08); display:grid; place-items:center; color:#fff}
.f-social a:hover{background:var(--pink); transform:translateY(-2px)}
.f-social svg{width:19px;height:19px}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; margin-top:54px; padding-top:24px; border-top:1px solid rgba(255,255,255,.1); font-size:13px; color:rgba(255,255,255,.5)}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr; gap:34px 24px}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:1; transform:none}
.reveal.in{opacity:1; transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1; transform:none; transition:none}}

/* ---------- Utility ---------- */
.grid{display:grid; gap:24px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}
.flex{display:flex}
.center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:24px}.mt-l{margin-top:40px}
.btn-row{display:flex; gap:14px; flex-wrap:wrap}
.divider{height:1px; background:var(--line); border:0; margin:0}

/* ---------- Ribbon / priority badge ---------- */
.priority-ribbon{display:inline-flex; align-items:center; gap:8px; background:var(--grad); color:#fff; padding:7px 15px; border-radius:var(--r-pill); font-weight:700; font-size:12.5px; letter-spacing:.04em; box-shadow:0 10px 24px -12px rgba(236,13,140,.7)}
.priority-ribbon svg{width:15px;height:15px}

/* star rating */
.stars{display:inline-flex; gap:2px; color:#FFB02E}
.stars svg{width:16px;height:16px}

/* media marquee / moving slider */
.marquee{position:relative; overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee-track{display:flex; align-items:center; gap:60px; width:max-content; animation:marq 36s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee .ml{font-family:'Bricolage Grotesque'; font-weight:700; font-size:27px; color:var(--muted-2); letter-spacing:-.02em; white-space:nowrap; flex:none; opacity:.62; transition:.3s var(--ease)}
.marquee .ml:hover{opacity:1; color:var(--ink)}
.marquee.on-ink .ml{color:#fff; opacity:.5}
.marquee.on-ink .ml:hover{opacity:1; color:#fff}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none; flex-wrap:wrap; justify-content:center; gap:24px 44px}}

/* language toggle */
.lang-btn{display:inline-flex; align-items:center; gap:6px; font-family:'Manrope'; font-weight:700; font-size:13.5px; color:var(--ink-700); border:1.5px solid var(--line); border-radius:var(--r-pill); padding:9px 13px; transition:.2s var(--ease); white-space:nowrap}
.lang-btn:hover{border-color:var(--pink-300); color:var(--pink-700)}
.lang-btn svg{width:15px;height:15px}

/* breadcrumb / page hero */
.page-hero{background:var(--grad-soft); padding:70px 0 60px; position:relative; overflow:hidden}
.page-hero .crumb{font-size:13.5px; font-weight:600; color:var(--pink-700); margin-bottom:14px}
.page-hero .crumb a{color:var(--muted)}
.page-hero .crumb a:hover{color:var(--pink)}


.form-feedback{display:none; margin:0 0 18px; padding:13px 15px; border-radius:14px; font-size:13.5px; font-weight:700}
.form-feedback.show{display:block}
.form-feedback.error{background:#fff1f4; color:#b0144f}
.form-feedback.success{background:#edfdf4; color:#13795b}
.visually-hidden{position:absolute!important; width:1px!important; height:1px!important; padding:0!important; margin:-1px!important; overflow:hidden!important; clip:rect(0,0,0,0)!important; white-space:nowrap!important; border:0!important}
