@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;600&display=swap');

:root{
  --brand-primary: #6f5bff;
  --brand-primary-strong: #5846f2;
  --brand-accent: #1cc8ee;
  --brand-surface: #ffffff;
  --brand-surface-weak: #f4f5fb;
  --brand-surface-strong: #edf0ff;
  --brand-text: #0f1225;
  --brand-text-secondary: #4a4f64;
  --brand-border: #e4e7f0;
  --brand-shadow: 0 20px 60px rgba(15, 18, 37, 0.18);
  --brand-radius: 16px;
  --brand-radius-small: 12px;
  --brand-blur: blur(12px);
  --container: 1100px;
}

/* Header nav hover highlight and scroll progress indicator */
.site-header .nav a{ transition: color .12s ease; }
.site-header .nav a:hover, .site-header .nav a:focus{ color: var(--brand-accent); }

/* Thin line at top indicating scroll progress */
#scrollIndicator{
  position:fixed;
  left:0;
  top:0;
  height:4px;
  width:0%;
  background: linear-gradient(90deg, var(--brand-accent), rgba(28,200,238,0.8));
  z-index:100000;
  transition: width 0.12s linear;
}

/* Partners landing: header background matches main landing background */
.partners-landing .site-header{background:radial-gradient(circle at 10% 10%, rgba(111,91,255,0.06), transparent 32%), radial-gradient(circle at 80% 0%, rgba(28,200,238,0.08), transparent 40%), var(--brand-surface-weak);border-bottom:1px solid var(--brand-border)}
*{box-sizing:border-box}
body{font-family: 'Manrope', -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;line-height:1.5;color:var(--brand-text);background:radial-gradient(circle at 10% 10%, rgba(111,91,255,0.06), transparent 32%), radial-gradient(circle at 80% 0%, rgba(28,200,238,0.08), transparent 40%), var(--brand-surface-weak);margin:0}

.container{max-width:var(--container);margin:0 auto;padding:28px}

.site-header{background:radial-gradient(circle at 10% 10%, rgba(111,91,255,0.06), transparent 32%), radial-gradient(circle at 80% 0%, rgba(28,200,238,0.08), transparent 40%), var(--brand-surface-weak);border-bottom:1px solid var(--brand-border);box-shadow: 0 20px 60px rgba(15,18,37,0.12)}
.header-row{display:flex;align-items:center;gap:16px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.brand{font-weight:800;color:var(--brand-primary);letter-spacing:0.6px}
.nav{display:flex;gap:18px;margin-left:24px}
.nav a{text-decoration:none;color:var(--brand-text-secondary);font-weight:600}
/* Active nav item for landing pages */
.nav a.active{color:var(--brand-primary);}
.actions{margin-left:auto;display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.btn{padding:10px 16px;border-radius:10px;text-decoration:none;display:inline-block}
.btn-primary{background:linear-gradient(135deg,var(--brand-primary-strong),#3a2bff);color:#fff;box-shadow:0 20px 60px rgba(56,36,255,0.18);border:none;transition:transform .12s ease, filter .12s ease}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.04)}
/* Make header "Open web" button brighter */
.actions .open-app.btn-primary{position:relative;z-index:2;overflow:visible;padding:10px 18px;background:linear-gradient(135deg,var(--brand-primary-strong),#3a2bff);box-shadow:0 18px 60px rgba(56,36,255,0.22)}
.actions .open-app.btn-primary::after{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:calc(100% + 80px);height:calc(100% + 48px);border-radius:18px;background:radial-gradient(60% 50% at 30% 28%, rgba(58,43,255,0.42), rgba(28,200,238,0.18) 36%, rgba(28,200,238,0.08) 56%, transparent 72%);filter:blur(28px);z-index:-1;transition:filter .12s ease, opacity .12s ease, transform .12s ease;opacity:1;box-shadow:0 30px 80px rgba(58,43,255,0.18);pointer-events:none}
.actions .open-app.btn-primary:hover::after{filter:blur(34px);opacity:1;transform:translate(-50%,-50%) scale(1.02)}
.btn-ghost{border:1px solid rgba(90,66,255,0.16);color:var(--brand-primary);background:transparent}
.btn-ghost:hover{background:rgba(90,66,255,0.06)}
.menu-toggle{display:none;background:transparent;border:none;font-size:18px}

.logo-img{width:40px;height:40px;margin-right:10px}

/* Hero */
.hero{padding:48px 0}
.hero-inner{display:flex;gap:28px;align-items:center;justify-content:space-between}
.hero-left{flex:1}
.hero-right{width:380px;display:flex;flex-direction:column;align-items:center;gap:12px}
.hero h1{font-size:36px;margin:0 0 12px}
.lead{color:var(--brand-text-secondary);max-width:620px}
.hero-ctas{margin-top:18px;display:flex;gap:12px}
.hero-features{display:flex;gap:12px;margin-top:18px;padding:0;list-style:none}
.hero-features li{background:var(--brand-surface);padding:8px 12px;border-radius:12px;color:var(--brand-text-secondary);border:1px solid var(--brand-border)}
.device-mock{width:320px;border-radius:20px;overflow:hidden;border:1px solid var(--brand-border);background:var(--brand-surface);padding:16px;box-shadow:var(--brand-shadow)}
.qr-small{background:var(--brand-surface);border-radius:12px;padding:12px;color:var(--brand-text-secondary);box-shadow:0 6px 20px rgba(2,6,23,0.04)}

.section-title{font-size:32px;margin-bottom:18px;font-weight:800;color:var(--brand-text)}

/* How it works */
.how{padding:36px 0}
.how-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.how-card{background:var(--brand-surface-weak);padding:24px;border-radius:20px;display:flex;align-items:stretch;border:1px solid var(--brand-border);box-shadow:var(--brand-shadow)}
.how-card .card-inner{width:100%;text-align:center}
.how-card .media{width:200px;height:200px;margin:0 auto 18px;border-radius:16px;background:var(--brand-surface);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 8px 26px rgba(15,18,37,0.06)}
.how-card .media img{max-width:100%;height:auto;display:block}
.how-card h3{font-size:20px;margin:8px 0 10px;color:var(--brand-text)}
.how-card .muted{color:var(--brand-text-secondary);max-width:320px;margin:0 auto}

/* Features */
.features{padding:36px 0}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:var(--brand-surface);padding:18px;border-radius:var(--brand-radius-small);border:1px solid var(--brand-border);box-shadow:var(--brand-shadow)}

/* Partners */
.partners{padding:36px 0}
.partners-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}
.partner-form{display:flex;flex-direction:column;gap:10px;padding:18px}
.partner-form label{display:flex;flex-direction:column;font-size:13px;color:var(--brand-text-secondary)}
.partner-form input{padding:10px;border-radius:8px;border:1px solid var(--brand-border);margin-top:8px}
.partner-info ul{margin:12px 0 0 16px}

/* Cookie banner */
.cookie-banner{position:fixed;left:24px;right:24px;bottom:20px;background:var(--brand-surface);border-radius:14px;padding:14px 18px;display:flex;gap:12px;align-items:center;box-shadow:var(--brand-shadow);border:1px solid var(--brand-border);z-index:1200}
.cookie-banner p{margin:0;color:var(--brand-text-secondary)}
.cookie-banner a{color:var(--brand-primary);text-decoration:underline}

/* Subscribe + FAQ */
.subscribe{padding:36px 0;text-align:center}
.subscribe-form{display:inline-flex;gap:10px;align-items:center}
.subscribe-form input{padding:12px 14px;border-radius:10px;border:1px solid var(--brand-border)}
.faq{padding:36px 0}
.contacts{padding:36px 0}
.contacts-grid{display:grid;grid-template-columns:1fr;gap:16px}
.contacts-card{padding:18px;border-radius:12px;background:var(--brand-surface);border:1px solid var(--brand-border)}
.faq-list details{background:var(--brand-surface);padding:14px;border-radius:12px;margin-bottom:10px;border:1px solid var(--brand-border)}
.muted{color:var(--brand-text-secondary)}

/* Pricing */
.pricing{padding:36px 0}
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.plan{background:var(--brand-surface);padding:20px;border-radius:var(--brand-radius-small);border:1px solid var(--brand-border)}
.plan.featured{border-color:var(--brand-primary)}
.price{font-size:20px;color:var(--brand-primary);margin:8px 0}

/* Steps numbers styling */
.steps-number{color:var(--brand-primary);font-weight:900}

/* Blog */
.blog{padding:36px 0}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.post img{width:100%;border-radius:10px}

/* Footer */
.site-footer{border-top:1px solid var(--brand-border);background:var(--brand-surface);padding:48px 0 24px;margin-top:36px}
.footer-grid{display:flex;justify-content:space-between;gap:24px;align-items:flex-start}
.site-footer{background: #0f0f10;color:#ddd}
.site-footer a{color:#ddd}
.footer-grid > div{flex:1}
.footer-grid .footer-logo{flex:0 0 auto;display:flex;align-items:center;justify-content:flex-end}
.footer-grid .footer-logo img{width:56px;height:56px}
.site-footer strong{color:#fff}
.site-footer p{color:#cfcfcf}
.site-footer .muted{color:#bdbdbd}

/* Footer columns layout like reference */
.footer-grid{display:flex;gap:40px}
.footer-grid a{display:block;margin-bottom:8px}

/* Responsive */
@media (max-width:900px){
  .container{padding:18px}
  .hero{padding:28px 0}
  .hero-inner{flex-direction:column;align-items:flex-start}
  .hero-right{width:100%;display:flex;justify-content:center}
  .hero-left{text-align:left}
  .hero h1{font-size:28px}
  .lead{max-width:100%}
  .nav{display:none}
  .menu-toggle{display:block}
  .nav.open{display:flex;position:fixed;left:12px;right:12px;top:64px;background:var(--brand-surface);flex-direction:column;padding:12px;border-radius:10px;box-shadow:var(--brand-shadow);z-index:1300}
  .features-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .how-cards{grid-template-columns:1fr}
  .partners-grid{grid-template-columns:1fr}
  .subscribe-form{flex-direction:column;gap:8px;width:100%}
  .cookie-banner{left:12px;right:12px;bottom:14px}
  .hero-ctas{justify-content:flex-start}
  .hero-features{flex-wrap:wrap}
  .hero-features li{margin-bottom:8px}
  .device-mock{width:260px}
  .how-card .media{width:140px;height:140px}
  .how-card .muted{max-width:100%}
  .partner-form input{width:100%}
}

/* Fixed header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1400}
main{margin-top:76px}

@media (max-width:900px){
  main{margin-top:72px}
}

@media (max-width:600px){
  .hero-inner{align-items:center}
  .hero-left{text-align:center}
  .hero h1{font-size:22px}
  .hero-right{display:none}
  .hero-ctas{flex-direction:column;align-items:center}
  /* Only make prominent hero/form buttons full-width on small screens, keep header buttons compact */
  .hero .btn, .hero-ctas .btn, .partner-form .btn, #partnerModal .partner-submit { width:100% }
  .hero-features{justify-content:center}
  .how-card{padding:18px}
  .how-card .media{width:120px;height:120px}
  .section-title{font-size:24px}
  .footer-grid{flex-direction:column;align-items:flex-start}
}

@media (max-width:420px){
  .container{padding:12px}
  .section-title{font-size:20px}
  .hero h1{font-size:20px}
  .lead{font-size:14px}
  .menu-toggle{font-size:20px}
  .partner-form label{font-size:13px}
  .nav{display:none}
  .menu-toggle{display:block;position:relative;z-index:99999}
}

/* Modal styles for partner form (updated to screenshot-like look) */
/* Backdrop: allow page-level scrolling if dialog taller than viewport, but keep centered by default */
#partnerModal .modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.78);display:flex;align-items:center;justify-content:center;z-index:9999;padding:28px;overflow-y:auto}
#partnerModal .modal-close{position:absolute;top:10px;right:10px;background:transparent;color:#0f1225;border:none;font-size:28px;line-height:1;cursor:pointer;z-index:10010;padding:6px}
/* Dialog: constrain height to viewport and make inner content scrollable */
#partnerModal .modal-dialog{position:relative;width:540px;max-width:100%;background:#fff;border-radius:8px;box-shadow:0 20px 50px rgba(0,0,0,0.5);overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 56px)}
#partnerModal .modal-illustration{height:160px;background:linear-gradient(180deg,#f7f7f9,#ffffff);background-size:cover;background-position:center;flex:0 0 auto}
#partnerModal .modal-body{padding:28px 32px 34px;text-align:center;overflow:auto;flex:1 1 auto;-webkit-overflow-scrolling:touch}
#partnerModal .modal-title{font-size:22px;margin:0 0 6px;font-weight:800}
#partnerModal .modal-sub{color:#666;font-size:14px;margin:0 0 18px}
#partnerModal .partner-form{display:flex;flex-direction:column;gap:10px}
#partnerModal .partner-form input{width:100%;display:block;margin:8px 0;padding:14px 16px;border-radius:12px;border:1px solid var(--brand-border);background:linear-gradient(180deg,var(--brand-surface),#ffffff);box-sizing:border-box;font-size:15px;color:var(--brand-text);transition:box-shadow .15s, border-color .15s}
#partnerModal .partner-form input::placeholder{color:#bfc4d6}
#partnerModal .partner-form input:focus{outline:none;border-color:var(--brand-primary-strong);box-shadow:0 6px 18px rgba(88,70,242,0.12)}
#partnerModal .partner-submit{margin-top:14px;background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-strong));color:#fff;border:none;padding:14px 18px;border-radius:12px;width:100%;font-weight:800;font-size:15px;cursor:pointer;box-shadow:var(--brand-shadow)}
#partnerModal .muted{color:#666;font-size:13px}
/* Inline field hints and invalid state */
#partnerModal .partner-form .field-hint{color:#d32f2f;display:none;margin-top:6px;font-size:13px;text-align:left}
#partnerModal .partner-form input.invalid{border-color:#d32f2f;box-shadow:0 6px 18px rgba(211,47,47,0.08)}
#partnerModal .partner-form .phone-group input.invalid{border-color:#d32f2f}
#partnerModal .partner-form .terms a{color:var(--brand-primary);text-decoration:underline}
@media (max-width:520px){
  /* Mobile: make modal use nearly full width with very small paddings */
  #partnerModal .modal-backdrop{padding:8px}
  #partnerModal .modal-dialog{width:100%;max-width:100%;max-height:calc(100vh - 16px);border-radius:10px}
  #partnerModal .modal-illustration{height:120px}
  #partnerModal .modal-body{padding:10px}
}

/* Brand highlight for short phrases */
.brand-highlight{display:inline-block;padding:6px 10px;border-radius:12px;background:linear-gradient(90deg, rgba(111,91,255,0.12), rgba(28,200,238,0.08));color:var(--brand-primary);font-weight:800}
.brand-highlight::first-letter{text-transform:uppercase}
/* Contacts + map block */
.partners-contact .hero-inner{display:flex;gap:20px;align-items:stretch}
.contact-panel{flex:1;padding:28px;background:#111;color:#fff;border-radius:12px}
.contact-panel h2{color:#fff}
.contact-map{flex:1;min-width:320px}
@media (max-width:900px){
  .partners-contact .hero-inner{flex-direction:column}
  .contact-map{order:2}
  .contact-panel{order:1}
}
