/* ================================================================
   CredMantri — Premium Offer Landing
   Design: "Verdant" — Fresh Mint · Mobile-First · Production Grade
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

/* ── Tokens ──────────────────────────────────────────────────── */
:root {
  --g50:  #f0fdf4; --g100: #dcfce7; --g200: #bbf7d0;
  --g300: #86efac; --g400: #4ade80; --g500: #22c55e;
  --g600: #16a34a; --g700: #15803d; --g800: #166534;
  --n0:   #ffffff; --n50:  #f8fafc; --n100: #f1f5f9;
  --n200: #e2e8f0; --n300: #cbd5e1; --n400: #94a3b8;
  --n500: #64748b; --n600: #475569; --n700: #334155;
  --n800: #1e293b; --n900: #0f172a;
  --clr-bg:           #edfbf2;
  --clr-surface:      var(--n0);
  --clr-primary:      var(--g500);
  --clr-primary-dk:   var(--g600);
  --clr-primary-lt:   var(--g100);
  --clr-border:       var(--n200);
  --clr-border-focus: var(--g400);
  --clr-text:         var(--n900);
  --clr-text-2:       var(--n500);
  --clr-text-3:       var(--n400);
  --clr-error:        #ef4444;
  --clr-error-bg:     #fff1f2;
  --ff-head: 'Bricolage Grotesque', sans-serif;
  --ff-body: 'Plus Jakarta Sans', sans-serif;
  --text-xs:   clamp(0.70rem, 2vw,   0.75rem);
  --text-sm:   clamp(0.82rem, 2.2vw, 0.875rem);
  --text-base: clamp(0.92rem, 2.5vw, 1rem);
  --text-lg:   clamp(1rem,    2.8vw, 1.125rem);
  --text-xl:   clamp(1.15rem, 3.5vw, 1.375rem);
  --text-2xl:  clamp(1.35rem, 4.5vw, 1.75rem);
  --text-3xl:  clamp(1.6rem,  6vw,   2.25rem);
  --text-4xl:  clamp(1.9rem,  7vw,   2.75rem);
  --sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;
  --sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--sp-16:64px;
  --r-sm:8px;--r-md:12px;--r-lg:18px;--r-xl:24px;--r-2xl:32px;--r-full:9999px;
  --sh-xs:  0 1px 3px rgba(0,0,0,.06);
  --sh-sm:  0 2px 8px rgba(0,0,0,.07);
  --sh-md:  0 6px 24px rgba(0,0,0,.09);
  --sh-lg:  0 16px 48px rgba(0,0,0,.11);
  --sh-xl:  0 28px 72px rgba(0,0,0,.13);
  --sh-grn-sm: 0 4px 16px rgba(34,197,94,.22);
  --sh-grn-md: 0 8px 32px rgba(34,197,94,.30);
  --sh-grn-lg: 0 16px 56px rgba(34,197,94,.38);
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --t-fast:150ms;--t-base:240ms;--t-slow:380ms;--t-xslow:560ms;
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);font-size:var(--text-base);line-height:1.65;
  color:var(--clr-text);background:var(--clr-bg);
  min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img,svg{display:block}
button,input{font:inherit}
a{color:inherit}

/* ── Keyframes ───────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse-ring{
  0%{box-shadow:0 0 0 0 rgba(34,197,94,.45)}
  70%{box-shadow:0 0 0 10px rgba(34,197,94,0)}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
@keyframes shimmer{
  0%{background-position:-200% center}
  100%{background-position:200% center}
}
@keyframes checkDraw{from{stroke-dashoffset:60}to{stroke-dashoffset:0}}
@keyframes blobFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(12px,-18px) scale(1.04)}
  66%{transform:translate(-10px,12px) scale(0.97)}
}
@keyframes scaleIn{to{transform:scaleX(1)}}
@keyframes progressGlow{
  0%,100%{box-shadow:none}
  50%{box-shadow:0 0 12px rgba(34,197,94,.5)}
}

/* ── Background ──────────────────────────────────────────────── */
.bg-layer{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-layer__blob{
  position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;
  animation:blobFloat 20s ease-in-out infinite;
}
.bg-layer__blob--a{
  width:min(520px,80vw);height:min(520px,80vw);top:-120px;right:-80px;
  background:radial-gradient(circle at 40% 40%,var(--g200),transparent 68%);
  animation-duration:22s;
}
.bg-layer__blob--b{
  width:min(380px,60vw);height:min(380px,60vw);bottom:60px;left:-80px;
  background:radial-gradient(circle at 60% 60%,var(--g100),transparent 70%);
  animation-duration:18s;animation-delay:-6s;
}
.bg-layer__blob--c{
  width:min(280px,50vw);height:min(280px,50vw);top:45%;left:40%;
  background:radial-gradient(circle,#d1fae5,transparent 72%);
  opacity:.3;animation-duration:25s;animation-delay:-11s;
}
.bg-layer::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(var(--g200) 1px,transparent 1px);
  background-size:28px 28px;opacity:.35;
}

/* ── Page ────────────────────────────────────────────────────── */
.page{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}

/* ── Navbar ──────────────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(24px) saturate(200%);
  -webkit-backdrop-filter:blur(24px) saturate(200%);
  border-bottom:1px solid rgba(255,255,255,.7);
  box-shadow:0 1px 0 var(--n200),var(--sh-xs);
}
.nav__inner{
  max-width:680px;margin:0 auto;padding:0 var(--sp-4);
  height:60px;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);
}
.nav__logo{height:34px;width:auto;flex-shrink:0}
.nav__pill{
  display:flex;align-items:center;gap:var(--sp-2);
  background:var(--g50);border:1px solid var(--g200);
  border-radius:var(--r-full);padding:5px var(--sp-3) 5px var(--sp-2);
  max-width:180px;overflow:hidden;
}
.nav__pill-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--g500);flex-shrink:0;
  animation:pulse-ring 2.2s ease-out infinite;
}
.nav__pill-text{display:flex;flex-direction:column;min-width:0;line-height:1.2}
.nav__pill-label{
  font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:var(--clr-text-3);
}
.nav__pill-name{
  font-size:var(--text-xs);font-weight:700;color:var(--g700);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ── Main ────────────────────────────────────────────────────── */
.main{
  flex:1;width:100%;max-width:680px;margin:0 auto;
  padding:var(--sp-6) var(--sp-4) var(--sp-12);
  display:flex;flex-direction:column;gap:var(--sp-5);
}

/* ── Hero ────────────────────────────────────────────────────── */
.hero{animation:fadeUp var(--t-xslow) var(--ease-out) both;padding-top:var(--sp-3)}
.hero__tag{
  display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,var(--g100),var(--g50));
  border:1px solid var(--g200);border-radius:var(--r-full);
  padding:5px 14px 5px 8px;font-size:var(--text-xs);
  font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--g700);
  margin-bottom:var(--sp-4);
}
.hero__tag svg{width:13px;height:13px;flex-shrink:0}
.hero__title{
  font-family:var(--ff-head);font-size:var(--text-4xl);
  font-weight:800;line-height:1.1;letter-spacing:-.03em;
  color:var(--n900);margin-bottom:var(--sp-2);
}
.hero__title em{
  font-style:normal;color:var(--g600);position:relative;
}
.hero__title em::after{
  content:'';position:absolute;bottom:0;left:0;
  width:100%;height:4px;
  background:linear-gradient(90deg,var(--g400),var(--g300));
  border-radius:2px;transform:scaleX(0);transform-origin:left;
  animation:scaleIn .5s var(--ease-out) .7s forwards;
}
.hero__sub{font-size:var(--text-base);color:var(--clr-text-2);max-width:46ch}

/* ── Banner ──────────────────────────────────────────────────── */
.banner{
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--sh-lg);
  animation:fadeUp var(--t-xslow) var(--ease-out) .1s both;
  position:relative;
}
.banner::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 55%,rgba(15,23,42,.18));
  pointer-events:none;
}
.banner img{width:100%;height:auto;object-fit:cover;display:block;transition:transform var(--t-slow) var(--ease-out)}
.banner:hover img{transform:scale(1.025)}

/* ── Trust ───────────────────────────────────────────────────── */
.trust{
  display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-2);
  animation:fadeUp var(--t-xslow) var(--ease-out) .18s both;
}
.trust__item{
  display:flex;align-items:center;gap:var(--sp-2);
  background:var(--n0);border:1px solid var(--n200);
  border-radius:var(--r-md);padding:var(--sp-3);
  font-size:var(--text-sm);font-weight:600;color:var(--n700);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.trust__item:hover{border-color:var(--g300);box-shadow:var(--sh-grn-sm)}
.trust__icon{
  width:32px;height:32px;border-radius:var(--r-sm);
  background:var(--g50);border:1px solid var(--g100);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--g600);
}
.trust__icon svg{width:15px;height:15px}

/* ── Card ────────────────────────────────────────────────────── */
.card{
  background:var(--n0);border-radius:var(--r-xl);
  border:1px solid rgba(34,197,94,.14);
  box-shadow:var(--sh-xl),0 0 0 1px rgba(34,197,94,.05);
  overflow:hidden;
  animation:fadeUp var(--t-xslow) var(--ease-out) .25s both;
}
.card__band{
  height:5px;
  background:linear-gradient(90deg,var(--g400) 0%,var(--g500) 50%,var(--g300) 100%);
  background-size:200% auto;animation:shimmer 3s linear infinite;
}
.card__body{padding:var(--sp-8) var(--sp-5)}

/* Form header */
.form-head{text-align:center;margin-bottom:var(--sp-8)}
.form-head__badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;
  background:linear-gradient(135deg,var(--g100),var(--g50));
  border:1.5px solid var(--g200);border-radius:var(--r-lg);
  color:var(--g700);margin:0 auto var(--sp-4);
}
.form-head__badge svg{width:26px;height:26px}
.form-head__title{
  font-family:var(--ff-head);font-size:var(--text-2xl);
  font-weight:800;letter-spacing:-.02em;color:var(--n900);margin-bottom:4px;
}
.form-head__sub{font-size:var(--text-sm);color:var(--clr-text-2)}

/* ── Fields ──────────────────────────────────────────────────── */
.fields{display:flex;flex-direction:column;gap:var(--sp-5)}
.fields--grid{display:grid;grid-template-columns:1fr;gap:var(--sp-5)}
.field{display:flex;flex-direction:column;gap:var(--sp-2)}
.field--full{grid-column:1/-1}

.field__label{
  display:flex;align-items:center;gap:4px;
  font-size:var(--text-xs);font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;color:var(--clr-text-2);
}
.field__req{color:var(--clr-error);font-size:10px}

.field__wrap{position:relative;display:flex;align-items:center}
.field__ico{
  position:absolute;left:14px;width:18px;height:18px;
  color:var(--clr-text-3);pointer-events:none;flex-shrink:0;
  transition:color var(--t-base);
}
.field__input{
  width:100%;
  padding:15px 44px 15px 44px;
  background:var(--n50);border:1.5px solid var(--clr-border);
  border-radius:var(--r-md);
  font-size:var(--text-base);font-weight:500;color:var(--n900);
  outline:none;-webkit-appearance:none;
  transition:border-color var(--t-base),background var(--t-base),box-shadow var(--t-base);
  min-height:52px;
}
.field__input::placeholder{color:var(--clr-text-3);font-weight:400}
.field__input:focus{
  border-color:var(--clr-border-focus);background:var(--n0);
  box-shadow:0 0 0 3.5px rgba(74,222,128,.18);
}
.field__wrap:focus-within .field__ico{color:var(--g500)}
.field__input--pan{text-transform:uppercase;letter-spacing:.08em}

/* Validation */
.field__input.ok{border-color:var(--g400);background:#f0fdf4}
.field__input.err{
  border-color:var(--clr-error);background:var(--clr-error-bg);
  box-shadow:0 0 0 3px rgba(239,68,68,.1);
}
.field__tick{
  position:absolute;right:14px;width:18px;height:18px;
  opacity:0;pointer-events:none;transition:opacity var(--t-fast);
}
.field__tick--ok{color:var(--g500)}
.field__tick--err{color:var(--clr-error)}
.field__input.ok  ~ .field__tick--ok  {opacity:1}
.field__input.err ~ .field__tick--err {opacity:1}

.field__hint{
  font-size:var(--text-xs);color:var(--clr-text-3);
  padding-left:2px;display:flex;align-items:center;gap:4px;
}
.field__hint.err{color:var(--clr-error)}
.field__hint svg{width:12px;height:12px;flex-shrink:0}

/* ── Consent ─────────────────────────────────────────────────── */
.consent{
  display:flex;gap:var(--sp-3);align-items:flex-start;
  background:var(--g50);border:1px solid var(--g100);
  border-radius:var(--r-md);padding:var(--sp-4);
}
.consent__box{
  flex-shrink:0;margin-top:2px;
  width:22px;height:22px;border-radius:6px;
  accent-color:var(--g500);cursor:pointer;
}
.consent__box.err{outline:2px solid var(--clr-error);outline-offset:2px}
.consent__text{font-size:var(--text-sm);color:var(--n600);line-height:1.55}
.consent__text strong{color:var(--n800)}
.consent__text a{
  color:var(--g700);font-weight:600;text-decoration:underline;
  text-decoration-color:rgba(21,128,61,.35);
}
.consent__text a:hover{text-decoration-color:var(--g700)}

/* ── Submit ──────────────────────────────────────────────────── */
.btn-submit{
  width:100%;min-height:56px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(160deg,var(--g500) 0%,var(--g600) 100%);
  color:#fff;font-family:var(--ff-head);
  font-size:var(--text-lg);font-weight:700;
  border:none;border-radius:var(--r-md);cursor:pointer;
  box-shadow:var(--sh-grn-md),inset 0 1px 0 rgba(255,255,255,.18);
  transition:transform var(--t-fast) var(--ease-out),box-shadow var(--t-base),background var(--t-base);
  position:relative;overflow:hidden;
  -webkit-tap-highlight-color:transparent;
}
.btn-submit::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(255,255,255,.18) 0%,transparent 60%);
  pointer-events:none;
}
.btn-submit:hover:not(:disabled){
  transform:translateY(-2px);
  box-shadow:var(--sh-grn-lg),inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-submit:active:not(:disabled){transform:translateY(0)}
.btn-submit:disabled{
  background:linear-gradient(160deg,var(--g300),var(--g400));
  box-shadow:none;cursor:not-allowed;transform:none;
}
.btn-submit__arrow{width:20px;height:20px;transition:transform var(--t-base) var(--ease-spring)}
.btn-submit:hover:not(:disabled) .btn-submit__arrow{transform:translateX(4px)}
.btn-submit__spinner{
  display:none;width:22px;height:22px;
  border:3px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;
  animation:spin .75s linear infinite;position:absolute;
}
.btn-submit.loading .btn-submit__label,
.btn-submit.loading .btn-submit__arrow{opacity:0}
.btn-submit.loading .btn-submit__spinner{display:block}

/* ── Security note ───────────────────────────────────────────── */
.sec-note{
  display:flex;align-items:center;justify-content:center;
  gap:6px;margin-top:var(--sp-4);
  font-size:var(--text-xs);color:var(--clr-text-3);text-align:center;
}
.sec-note svg{width:13px;height:13px;color:var(--g400);flex-shrink:0}

/* ── Footer ──────────────────────────────────────────────────── */
.foot{
  text-align:center;padding:var(--sp-8) var(--sp-4);
  font-size:var(--text-xs);color:var(--clr-text-3);
  border-top:1px solid var(--n200);background:rgba(255,255,255,.6);
  backdrop-filter:blur(8px);
}
.foot a{color:var(--g600);font-weight:600;text-decoration:none}
.foot a:hover{text-decoration:underline}
.foot__links{display:flex;justify-content:center;gap:var(--sp-4);margin-top:var(--sp-2)}

/* ── Modal (bottom sheet on mobile, centred on tablet+) ──────── */
.modal-bg{
  position:fixed;inset:0;z-index:999;
  background:rgba(15,23,42,.55);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:flex-end;justify-content:center;
  padding:0;opacity:0;visibility:hidden;
  transition:opacity var(--t-base) var(--ease-out),visibility var(--t-base);
}
.modal-bg.open{opacity:1;visibility:visible}
.modal-sheet{
  background:var(--n0);
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  padding:var(--sp-6) var(--sp-6) max(var(--sp-8),env(safe-area-inset-bottom));
  width:100%;max-width:520px;text-align:center;
  transform:translateY(100%);
  transition:transform var(--t-slow) var(--ease-out);
  position:relative;
}
.modal-bg.open .modal-sheet{transform:translateY(0)}
.modal-handle{
  width:40px;height:4px;border-radius:2px;
  background:var(--n200);margin:0 auto var(--sp-6);
}
.modal-ring{
  width:72px;height:72px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto var(--sp-5);
}
.modal-ring--loading{
  border:4px solid var(--n200);border-top-color:var(--g500);
  animation:spin .85s linear infinite;background:transparent;
}
.modal-ring--success{
  background:linear-gradient(135deg,var(--g100),var(--g50));
  border:2px solid var(--g200);animation:none;
}
.modal-ring--error{
  background:linear-gradient(135deg,#fff1f2,#fff5f5);
  border:2px solid #fecaca;animation:none;
}
.modal-ring svg{width:34px;height:34px}
.modal-ring--success svg{color:var(--g600)}
.modal-ring--error  svg{color:var(--clr-error)}
.modal-title{
  font-family:var(--ff-head);font-size:var(--text-2xl);
  font-weight:800;letter-spacing:-.02em;color:var(--n900);margin-bottom:var(--sp-2);
}
.modal-msg{font-size:var(--text-sm);color:var(--clr-text-2);line-height:1.6;margin-bottom:var(--sp-5)}
.modal-prog{
  height:6px;background:var(--n100);border-radius:var(--r-full);
  overflow:hidden;margin-top:var(--sp-5);display:none;
}
.modal-prog.show{display:block}
.modal-prog__fill{
  height:100%;width:0;
  background:linear-gradient(90deg,var(--g400),var(--g500));
  border-radius:var(--r-full);transition:width 2.2s linear;
  animation:progressGlow 1.5s ease-in-out infinite;
}
.modal-btn{
  display:none;align-items:center;justify-content:center;gap:8px;
  padding:14px var(--sp-8);border-radius:var(--r-md);border:none;
  font-family:var(--ff-head);font-size:var(--text-base);font-weight:700;
  cursor:pointer;width:100%;
  transition:transform var(--t-fast),box-shadow var(--t-base);
}
.modal-btn.show{display:flex}
.modal-btn--ok{background:linear-gradient(160deg,var(--g500),var(--g600));color:#fff;box-shadow:var(--sh-grn-sm)}
.modal-btn--err{background:linear-gradient(160deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 16px rgba(239,68,68,.28)}
.modal-btn:hover{transform:translateY(-1px)}
.check-path{stroke-dasharray:60;stroke-dashoffset:60;animation:checkDraw .45s var(--ease-out) .1s forwards}

/* ── Responsive ──────────────────────────────────────────────── */
@media(min-width:480px){
  .fields--grid{grid-template-columns:1fr 1fr}
  .field--full{grid-column:1/-1}
}
@media(min-width:560px){
  .nav__inner{height:68px}
  .nav__logo{height:38px}
  .main{padding:var(--sp-8) var(--sp-6) var(--sp-16)}
  .card__body{padding:var(--sp-10) var(--sp-10)}
  .trust{grid-template-columns:repeat(4,1fr)}
  .modal-bg{align-items:center;padding:var(--sp-6)}
  .modal-sheet{
    border-radius:var(--r-xl);max-width:440px;
    padding:var(--sp-10) var(--sp-8) var(--sp-8);
    transform:scale(.9) translateY(16px);
  }
  .modal-bg.open .modal-sheet{transform:scale(1) translateY(0)}
  .modal-handle{display:none}
}
@media(min-width:720px){
  .main{padding:var(--sp-10) var(--sp-8) var(--sp-16)}
}

/* ── Utility ─────────────────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
