/* =====================================================
   Village Coin Shop — Invest with VCS (Seller)
   Nightfall+FX Dark Glass + Neon Glow (Slider v1)
   ===================================================== */

/* ---------- Page backdrop ---------- */
body.dark{
  --bg:#0b1220; --bg-2:#0d1628; --card:#0f172a;
  --ink:#e9f1ff; --muted:#9fb2d7; --line:rgba(255,255,255,.12);
  --brand:#5b9dff; --mint:#34d399; --cyan:#22d3ee; --ok:#22c55e;
  --glass:rgba(255,255,255,.06);
  --radius:18px; --shadow:0 22px 60px rgba(0,0,0,.55);

  background:
    radial-gradient(1200px 500px at 15% 0%, rgba(91,157,255,.18), transparent 60%),
    radial-gradient(900px 500px at 85% 10%, rgba(34,211,238,.16), transparent 60%),
    linear-gradient(180deg, #0a1120, #0a1328 40%, #0b142c);
  color:var(--ink);
}

/* floating particles */
body.dark::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(3px 3px at 10% 20%, rgba(255,255,255,.08), transparent),
    radial-gradient(3px 3px at 80% 30%, rgba(255,255,255,.06), transparent),
    radial-gradient(2px 2px at 40% 70%, rgba(255,255,255,.05), transparent),
    radial-gradient(2px 2px at 70% 80%, rgba(255,255,255,.05), transparent);
  animation: drift 14s linear infinite;
}
@keyframes drift{
  0%{transform:translateY(0);opacity:.9}
  50%{transform:translateY(-10px);opacity:.7}
  100%{transform:translateY(0);opacity:.9}
}

/* ---------- Container ---------- */
.invest-wrap{ max-width:1100px; margin:18px auto 40px; position:relative; z-index:1; }
.form-card.invest-wrap{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)), var(--bg-2);
  border:1px solid var(--line);
  border-radius:calc(var(--radius) + 4px);
  box-shadow:0 20px 70px rgba(2,6,23,.7), inset 0 0 0 1px rgba(255,255,255,.05);
  padding:24px;
}

/* ---------- Hero ---------- */
.invest-hero{ text-align:center; margin-bottom:28px; }
.invest-hero h2{ margin:0; font-size:2rem; font-weight:800; letter-spacing:.3px; }
.invest-hero .muted{ color:var(--muted); margin-top:6px; }

/* ---------- Section title underline glow ---------- */
.sect-title{ position:relative; display:inline-block; padding-bottom:6px; margin-bottom:14px; }
.sect-title::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:2px;
  background:linear-gradient(90deg, rgba(91,157,255,.85), rgba(34,211,238,.8), rgba(52,211,153,.8));
  border-radius:999px; filter:drop-shadow(0 0 6px rgba(34,211,238,.45));
  animation: underlineSweep 2.6s ease-in-out infinite;
}
@keyframes underlineSweep{
  0%,100%{opacity:.9; filter:drop-shadow(0 0 6px rgba(34,211,238,.45))}
  50%{opacity:1; filter:drop-shadow(0 0 12px rgba(91,157,255,.65))}
}

/* ---------- Plans Grid ---------- */
.plans{ margin-bottom:34px; }
.plans-grid{ display:grid; gap:22px; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.plan-card{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)), var(--card);
  border:1px solid var(--line); border-radius:var(--radius);
  padding:22px; text-align:center; box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, outline-color .2s ease;
  position:relative; overflow:hidden;
  outline: 0 solid rgba(52,211,153,.0);
}
.plan-card::before{
  content:""; position:absolute; inset:-1px;
  background:
    radial-gradient(400px 120px at 50% -20%, rgba(91,157,255,.25), transparent 60%),
    radial-gradient(500px 160px at -10% 110%, rgba(52,211,153,.18), transparent 60%);
  opacity:.6; pointer-events:none;
}
.plan-card:hover{
  transform:translateY(-4px);
  box-shadow:0 26px 84px rgba(0,0,0,.65);
  border-color:rgba(91,157,255,.4);
  outline-width: 3px; outline-color: rgba(91,157,255,.25);
}
.plan-amount{ font-size:1.05rem; font-weight:700; margin-bottom:6px; color:var(--ink); }
.plan-rate{ font-size:1.8rem; font-weight:800; color:var(--mint); text-shadow:0 0 16px rgba(52,211,153,.5); margin-bottom:6px; }
.plan-note{ font-size:.92rem; color:var(--muted); }
.plan-card.active{
  border-color:rgba(52,211,153,.6);
  box-shadow:0 28px 88px rgba(16,185,129,.45), inset 0 0 0 1px rgba(16,185,129,.25);
  animation: activeSpark 1.8s ease-in-out infinite;
}
@keyframes activeSpark{
  0%,100%{outline-width:0px; outline-color:transparent}
  50%{outline:3px solid rgba(52,211,153,.18)}
}

/* ---------- ROI Calculator ---------- */
.roi{ margin-top:10px; }
.roi-form{ display:flex; flex-direction:column; gap:16px; }

/* Controls row */
.roi-controls{ display:grid; gap:18px; grid-template-columns:1fr; }
.fld{ display:flex; flex-direction:column; gap:8px; }
#amtInput{
  padding:12px 14px; font-size:1.02rem; color:var(--ink);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border:1px solid var(--line); border-radius:12px; outline:none;
  transition:border-color .15s, box-shadow .15s, transform .15s;
}
#amtInput:focus{
  border-color:rgba(91,157,255,.55);
  box-shadow:0 8px 28px rgba(91,157,255,.25);
  transform:translateY(-1px);
}
.help{ font-size:.86rem; color:var(--muted); }

/* ---------- Glass Range Slider ---------- */
.roi-box{
  position:relative;
  padding:28px 24px 34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015)),
    var(--card);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
.roi-box::after{
  content:"";
  position:absolute; inset:0; pointer-events:none;
  background: repeating-linear-gradient(
    90deg,
    rgba(255,255,255,.04) 0, rgba(255,255,255,.04) 2px,
    transparent 2px, transparent 8px
  );
  opacity:.25; mix-blend-mode:overlay;
  animation: pan 10s linear infinite;
}
@keyframes pan{ 0%{transform:translateX(0)} 100%{transform:translateX(-80px)} }

/* value bubble */
.roi-value{
  text-align:center;
  font-weight:900;
  font-size: clamp(22px, 3.2vw, 38px);
  color:#34d399;
  letter-spacing:.5px;
  margin-bottom:16px;
  filter: drop-shadow(0 2px 12px rgba(52,211,153,.25));
  animation: shimmer 3s ease-in-out infinite;
  transition: transform .25s ease;
}
.roi-value.bump{ transform:scale(1.08); }
@keyframes shimmer{
  0%,100%{ text-shadow: 0 0 10px rgba(52,211,153,.25), 0 0 0 rgba(91,157,255,0) }
  50%{ text-shadow: 0 0 18px rgba(52,211,153,.50), 0 0 12px rgba(91,157,255,.25) }
}

/* slider track */
#amtSlider{
  -webkit-appearance:none; appearance:none;
  width:100%; height:16px; border-radius:999px;
  background: linear-gradient(90deg, rgba(52,211,153,.35), rgba(91,157,255,.30));
  outline:none;
  box-shadow: inset 0 2px 8px rgba(0,0,0,.35), 0 1px 0 rgba(255,255,255,.06);
  position:relative;
  transition: box-shadow .2s ease, transform .2s ease;
  background-repeat:no-repeat;
  background-image: linear-gradient(90deg, rgba(52,211,153,1), rgba(91,157,255,1));
  background-size: 0% 100%;
}
#amtSlider:focus{ box-shadow: 0 0 0 3px rgba(91,157,255,.22), inset 0 2px 8px rgba(0,0,0,.35); }
#amtSlider:active{ transform:scale(1.01); }

/* slider thumb */
#amtSlider::-webkit-slider-thumb{
  -webkit-appearance:none; appearance:none;
  width:30px; height:30px; border-radius:50%;
  background: radial-gradient(circle at 35% 35%, #c8fff1, #4ade80 60%, #10b981);
  box-shadow:0 12px 26px rgba(16,185,129,.45), 0 0 0 4px rgba(255,255,255,.12) inset;
  cursor:pointer; border:none;
  transition: transform .12s ease, box-shadow .18s ease;
  animation: pulseGlow 2.4s ease-in-out infinite;
}
#amtSlider::-moz-range-thumb{
  width:30px; height:30px; border-radius:50%;
  background: radial-gradient(circle at 35% 35%, #c8fff1, #4ade80 60%, #10b981);
  box-shadow:0 12px 26px rgba(16,185,129,.45), 0 0 0 4px rgba(255,255,255,.12) inset;
  cursor:pointer; border:none;
  transition: transform .12s ease, box-shadow .18s ease;
  animation: pulseGlow 2.4s ease-in-out infinite;
}
#amtSlider:active::-webkit-slider-thumb,
#amtSlider:active::-moz-range-thumb{
  transform: scale(1.08);
  box-shadow:0 16px 32px rgba(16,185,129,.55), 0 0 0 5px rgba(255,255,255,.16) inset, 0 0 18px 6px rgba(34,211,238,.28);
}
@keyframes pulseGlow{
  0%,100%{ box-shadow:0 12px 26px rgba(16,185,129,.45), 0 0 0 4px rgba(255,255,255,.12) inset }
  50%{ box-shadow:0 16px 34px rgba(16,185,129,.55), 0 0 0 4px rgba(255,255,255,.18) inset, 0 0 16px 4px rgba(34,211,238,.22) }
}

/* ticks */
.roi-ticks{ position:relative; height:22px; margin-top:12px; }
.roi-ticks .tick{
  position:absolute; top:0; transform:translateX(-50%);
  width:2px; height:12px; background:rgba(255,255,255,.16); border-radius:2px;
}
.roi-ticks .tick.major{ height:16px; background:rgba(255,255,255,.28); }
.roi-ticks .lbl{
  position:absolute; top:14px; transform:translateX(-50%); white-space:nowrap;
  font-size:.78rem; color:var(--muted);
  text-shadow: 0 1px 0 rgba(0,0,0,.35);
}

/* ---------- Tier chips ---------- */
.roi-chipline{ display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.chip{
  background:rgba(255,255,255,.06); border:1px solid var(--line);
  color:var(--ink); border-radius:999px; padding:6px 14px; font-size:.92rem;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
.chip strong{ color:var(--ink); }

/* ---------- Returns Grid ---------- */
.returns-grid{ display:grid; grid-template-columns:repeat(4, minmax(180px,1fr)); gap:14px; margin-top:16px; }
.ret-card{
  padding:14px; border-radius:14px; position:relative; overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)), var(--card);
  border:1px solid var(--line); box-shadow:var(--shadow); text-align:center;
}
.ret-card::after{
  content:""; position:absolute; inset:-1px; pointer-events:none; opacity:.5;
  background: radial-gradient(400px 160px at 120% -20%, rgba(34,211,238,.22), transparent 60%);
  animation: glint 4.2s ease-in-out infinite;
}
@keyframes glint{
  0%,100%{opacity:.35; transform:translateX(-4%)}
  50%{opacity:.8; transform:translateX(4%)}
}
.ret-title{ color:var(--muted); font-size:.92rem; margin-bottom:6px; }
.ret-val{
  font-size:1.35rem; font-weight:800; color:var(--ok);
  text-shadow:0 0 14px rgba(34,197,94,.35);
  animation: floatUp 2.2s ease-in-out infinite;
}
@keyframes floatUp{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-2px) } }

/* ---------- Actions & Fine print ---------- */
.roi-actions{ text-align:center; margin-top:10px; }
.roi-actions .btn{ padding:10px 24px; font-weight:600; }
.fineprint{ margin-top:26px; font-size:.86rem; color:var(--muted); text-align:center; line-height:1.5; }

/* ---------- Responsive ---------- */
@media (max-width: 900px){ .returns-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); } }
@media (max-width: 520px){ .returns-grid{ grid-template-columns:1fr; } }

.roi-ticks .lbl.fancy {
  font-weight:700;
  font-size:.85rem;
  color:var(--brand);
  letter-spacing:0.5px;
  text-shadow:0 0 6px rgba(91,157,255,.5), 0 0 12px rgba(34,211,238,.35);
  transform:translateX(-50%) translateY(2px);
}

/* more breathing room under the slider */
.roi-box{ padding:28px 24px 46px; }          /* was 34px */

/* ticks area: allow positioning but keep inside */
.roi-ticks{
  position:relative; height:26px; margin-top:12px;
  overflow:visible;   /* labels can position, while we clamp via JS */
}

/* stylish short labels */
.roi-ticks .lbl.fancy{
  font-weight:800;
  font-size:.9rem;
  color:var(--brand);
  letter-spacing:.4px;
  text-shadow:0 0 6px rgba(91,157,255,.5), 0 0 12px rgba(34,211,238,.35);
  user-select:none;
  top:16px;                              /* a bit lower so it doesn't clip */
}

/* optional: nudge start/end labels a hair inward on very small screens */
@media (max-width: 420px){
  .roi-ticks .lbl.fancy{ font-size:.82rem; }
}

/* remove arrows / spinners from number field */
#amtInput[type="number"]{
  -moz-appearance: textfield;  /* Firefox */
  appearance: textfield;       /* Standard */
}

/* Chrome / Safari / Edge (Blink/WebKit) */
#amtInput::-webkit-outer-spin-button,
#amtInput::-webkit-inner-spin-button{
  -webkit-appearance: none;
  appearance: none;            /* Standard — fixes VS Code warning */
  margin: 0;
}

/* ---------- Header Layout ---------- */
.dash-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 20px;
  background:var(--card,rgba(255,255,255,0.04));
  border-bottom:1px solid var(--line,rgba(255,255,255,0.08));
}

/* ---------- Button Styles ---------- */
.btn-glass{
  display:inline-block;
  margin-left:12px;
  padding:8px 16px;
  border-radius:12px;
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  color:var(--ink,#fff);
  background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(6px);
  transition:all .25s ease;
}
.btn-glass:hover{
  background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,.08));
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(0,0,0,.35);
}

/* Special variant for logout */
.btn-glass.danger{
  border:1px solid rgba(239,68,68,.5);
  color:#f87171;
}
.btn-glass.danger:hover{
  background:linear-gradient(135deg,rgba(239,68,68,.25),rgba(239,68,68,.15));
  color:#fff;
}

/* ============================== */
/* Invest with VCS — page extras  */
/* (top bar + licenses scroller)  */
/* ============================== */

/* ---- Top bar ---- */
.sd-top{
  max-width:1200px; margin:12px auto; padding:10px 20px;
  display:flex; justify-content:space-between; align-items:center;
  background:var(--card,rgba(255,255,255,.04));
  border-radius:12px; border:1px solid rgba(255,255,255,.08);
}
.sd-brand{font-weight:700; font-size:18px; color:var(--ink,#fff); display:flex; align-items:center;}
.sd-brand .dot{width:10px; height:10px; border-radius:50%; background:var(--brand,#5b9dff); display:inline-block; margin-right:8px;}
.sd-actions a{
  display:inline-block; margin-left:12px; padding:8px 16px; border-radius:12px;
  font-size:14px; font-weight:600; text-decoration:none; color:var(--ink,#fff);
  background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.2); backdrop-filter:blur(6px); transition:all .25s ease;
}
.sd-actions a:hover{background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,.08)); transform:translateY(-2px); box-shadow:0 6px 16px rgba(0,0,0,.35);}
.sd-actions a.ghost{border:1px solid rgba(239,68,68,.5); color:#f87171;}
.sd-actions a.ghost:hover{background:linear-gradient(135deg,rgba(239,68,68,.25),rgba(239,68,68,.15)); color:#fff;}

/* ---- Licensed logos strip ---- */
.licenses{margin-top:24px;}
.licenses .lic-title{margin:0 0 10px 0;}
.logo-strip{
  position:relative; overflow:hidden; border-radius:12px;
  background:var(--bg-2,rgba(255,255,255,.02));
  border:1px solid var(--line,rgba(255,255,255,.08));
}
.logo-track{
  display:flex; gap:0; width:max-content;
  animation:logoscroll 22s linear infinite;
}
.logo-item{flex:0 0 auto; padding:14px 28px; filter:grayscale(100%) opacity(.9); transition:filter .2s ease, transform .2s ease;}
.logo-item img{height:48px; width:auto; display:block;}
.logo-item:hover{filter:grayscale(0%) opacity(1); transform:translateY(-2px);}
.logo-fallback{padding:14px 28px; display:block; color:var(--muted,#9fb2d7);}

@keyframes logoscroll{from{transform:translateX(0);} to{transform:translateX(-50%);}}

/* Pause on hover (optional) */
.logo-strip:hover .logo-track{animation-play-state:paused;}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){ .logo-track{animation:none;} }

/* Mobile tweaks */
@media (max-width:640px){
  .logo-item{padding:12px 18px;}
  .logo-item img{height:40px;}
}

/* ---- Licensed logos strip ---- */
.licenses{margin-top:24px; text-align:center;}
.licenses .lic-title{
  margin:0 0 14px 0;
  font-size:20px;
  font-weight:700;
  text-align:center;      /* ⬅️ center heading */
}

.logo-strip{
  position:relative; 
  overflow:hidden; 
  border-radius:12px;
  background:var(--bg-2,rgba(255,255,255,.02));
  border:1px solid var(--line,rgba(255,255,255,.08));
}

.logo-track{
  display:flex; 
  gap:0; 
  width:max-content;
  animation:logoscroll 22s linear infinite;
}

.logo-item{
  flex:0 0 auto;
  padding:18px 36px;       /* ⬅️ padding बढ़ा दी */
  filter:grayscale(100%) opacity(.9);
  transition:filter .2s ease, transform .2s ease;
}
.logo-item img{
  height:80px;             /* ⬅️ logos बड़े किए */
  width:auto; 
  display:block;
}
.logo-item:hover{
  filter:grayscale(0%) opacity(1);
  transform:translateY(-3px);
}
.logo-fallback{
  padding:18px 36px;
  display:block; 
  color:var(--muted,#9fb2d7);
}

@keyframes logoscroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* Pause on hover */
.logo-strip:hover .logo-track{animation-play-state:paused;}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){.logo-track{animation:none;}}

/* Mobile tweaks */
@media (max-width:640px){
  .logo-item{padding:14px 20px;}
  .logo-item img{height:60px;}   /* ⬅️ mobile पर भी बड़ा */
}

.logo-item{
  flex:0 0 auto;
  padding:18px 36px;
  filter:grayscale(100%) opacity(.9);
  transition:filter .2s ease, transform .2s ease;
  text-align:center;
}
.logo-item img{
  height:80px;
  width:auto;
  display:block;
  margin:0 auto 8px; /* नीचे थोड़ी space */
}
.logo-name{
  font-size:14px;
  font-weight:600;
  color:var(--muted,#9fb2d7);
  letter-spacing:0.5px;
}
.logo-item:hover{
  filter:grayscale(0%) opacity(1);
  transform:translateY(-3px);
}

/* Back Button (vinodjangid07) */
.button {
  width: 110px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  cursor: pointer;
  border: 2px solid rgb(255, 239, 94);
  background-color: rgb(255, 239, 94);
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.15);
  border-radius: 6px;
}

.button .text {
  width: 70%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgb(27, 27, 27);
  color: white;
  font-size: 14px;
  font-weight: 600;
}

.button .arrow path {
  fill: rgb(19, 19, 19);
}

.button:hover .arrow {
  animation: slide-in-left 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
}

@keyframes slide-in-left {
  0% {
    transform: translateX(-8px);
    opacity: 0;
  }
  100% {
    transform: translateX(0px);
    opacity: 1;
  }
}

.button:active {
  transform: scale(0.96);
}

/* Ensure Seller Login modal steps stay hidden until JS shows them */
.sl-section.hidden {
  display: none !important;
}

/* Prevent Register button inside login modal from inheriting green hover */
#slOverlay .btn-register:hover {
  background-position: initial !important;
  background-image: linear-gradient(45deg,#FF512F 0%,#F09819 51%,#FF512F 100%) !important;
  color: #fff !important;
  transform: none !important;
  box-shadow: 0 0 10px -5px #f09819 !important;
}
