:root{
  --bg:#070d1c;
  --bg2:#0b1733;
  --text:#eaf1ff;
  --muted:#9bb0d0;
  --blue:#3b82f6;
  --blue2:#1d4ed8;
  --blue-light:#60a5fa;
  --ok:#22c55e;
  --err:#ef4444;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%}
body{
  background:
    radial-gradient(1200px 800px at 50% -10%, #1e3a8a 0%, transparent 55%),
    radial-gradient(900px 600px at 90% 110%, #1e40af 0%, transparent 55%),
    linear-gradient(180deg,#070d1c 0%,#0b1733 100%);
  background-attachment:fixed;
  color:var(--text);
  font:16px/1.55 -apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Inter,Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:48px 20px;
  min-height:100vh;
  overflow-x:hidden;
}

/* ===== Animated background orbs ===== */
.aurora{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.orb{
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
  opacity:.55;
  mix-blend-mode:screen;
  animation:float 18s ease-in-out infinite;
}
.orb.o1{width:520px;height:520px;background:#3b82f6;top:-180px;left:-120px;animation-delay:0s}
.orb.o2{width:460px;height:460px;background:#60a5fa;top:30%;right:-180px;animation-delay:-6s}
.orb.o3{width:600px;height:600px;background:#1d4ed8;bottom:-260px;left:30%;animation-delay:-12s}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(40px,-30px) scale(1.05)}
  66%{transform:translate(-30px,40px) scale(.97)}
}
.grid-overlay{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(circle at 50% 50%, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(circle at 50% 50%, #000 30%, transparent 75%);
}

/* ===== Hero ===== */
.hero{
  width:100%;
  max-width:560px;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:28px;
}

.brand-mark{
  display:inline-flex;
  filter:drop-shadow(0 12px 32px rgba(59,130,246,.55));
  animation:pop .7s cubic-bezier(.4,0,.2,1) both;
}
@keyframes pop{from{opacity:0;transform:translateY(-10px) scale(.9)}to{opacity:1;transform:none}}

h1{
  font-size:clamp(28px,5vw,40px);
  font-weight:800;
  line-height:1.18;
  letter-spacing:-.02em;
  text-wrap:balance;
}
.grad{
  background:linear-gradient(135deg,#93c5fd 0%,#60a5fa 50%,#3b82f6 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* ===== CTA Button ===== */
.btn-cta{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:20px 48px;
  border-radius:18px;
  font-size:17px;
  font-weight:700;
  letter-spacing:.005em;
  color:#fff;
  text-decoration:none;
  background:linear-gradient(180deg,#3b82f6,#1d4ed8);
  box-shadow:
    0 1px 0 rgba(255,255,255,.25) inset,
    0 -2px 12px rgba(0,0,0,.2) inset,
    0 18px 40px -12px rgba(59,130,246,.7),
    0 0 0 1px rgba(147,197,253,.25);
  transition:transform .15s,box-shadow .25s,filter .2s;
  isolation:isolate;
  min-width:280px;
  overflow:hidden;
}
.btn-cta:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn-cta:active{transform:translateY(0);filter:brightness(.95)}
.btn-cta:disabled,.btn-cta[aria-disabled="true"]{filter:grayscale(.5);opacity:.6;cursor:not-allowed;transform:none}
.btn-cta svg{flex-shrink:0}

/* Secondary CTA — outlined / softer for demo button */
.btn-cta-secondary{
  background:rgba(255,255,255,.05);
  color:#bfd5ff;
  box-shadow:
    0 1px 0 rgba(255,255,255,.08) inset,
    0 0 0 1px rgba(147,197,253,.35),
    0 12px 28px -16px rgba(59,130,246,.55);
  border:none;
  cursor:pointer;
  font-family:inherit;
  min-width:280px;
}
.btn-cta-secondary:hover{
  background:rgba(59,130,246,.15);
  color:#ffffff;
  filter:none;
}
.btn-cta-secondary[aria-busy="true"]{
  opacity:.7;cursor:wait;transform:none;filter:none;
}

/* Demo issuance result block */
.demo-result{
  width:100%;
  max-width:520px;
  background:#ffffff;
  color:#0b1733;
  border-radius:16px;
  padding:18px 22px;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.08);
  text-align:left;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.demo-result-head{
  display:flex;align-items:center;gap:10px;
  font-size:15px;
}
.demo-result-icon{
  display:inline-block;
  width:26px;height:26px;border-radius:50%;
  background:#10b981;color:#fff;font-weight:900;text-align:center;line-height:26px;
}
.demo-result-meta{
  margin:0;font-size:13.5px;color:#3b4961;line-height:1.5;
}
.demo-link-row{
  display:flex;gap:8px;
}
.demo-link-row input{
  flex:1;min-width:0;
  padding:10px 12px;
  border:1px solid rgba(11,23,51,.15);
  border-radius:10px;
  font-family:ui-monospace,Menlo,Consolas,monospace;
  font-size:13px;
  color:#0b1733;
  background:#f3f6fc;
}
.demo-link-row button{
  padding:10px 16px;
  border:none;border-radius:10px;
  background:#1d4ed8;color:#fff;font-weight:600;
  cursor:pointer;
  font-family:inherit;
  font-size:14px;
}
.demo-link-row button:hover{background:#2563eb}
.demo-result.is-error{
  background:#fef2f2;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.45), 0 0 0 1px rgba(239,68,68,.3);
}
.demo-result.is-error .demo-result-icon{background:#ef4444}

/* ===== Modal ===== */
.modal{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  animation:modalFade .25s ease-out;
}
.modal[hidden]{display:none}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.modal-backdrop{
  position:absolute;inset:0;
  background:radial-gradient(800px 600px at 50% 40%, rgba(29,78,216,.35), rgba(4,10,28,.85) 70%);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.modal-card{
  position:relative;
  width:100%;
  max-width:440px;
  padding:36px 32px 26px;
  text-align:center;
  border-radius:24px;
  color:var(--text);
  background:
    linear-gradient(180deg, rgba(20,35,72,.92), rgba(11,23,51,.95));
  box-shadow:
    0 30px 80px -20px rgba(2,6,23,.85),
    0 0 0 1px rgba(147,197,253,.18),
    0 0 80px -20px rgba(59,130,246,.45),
    inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  animation:modalPop .3s cubic-bezier(.2,.9,.3,1.2);
  isolation:isolate;
  overflow:hidden;
}
.modal-card::before{
  content:"";
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(400px 200px at 50% -50px, rgba(59,130,246,.35), transparent 60%),
    radial-gradient(300px 200px at 50% 110%, rgba(96,165,250,.18), transparent 70%);
  pointer-events:none;
}
@keyframes modalPop{
  from{opacity:0;transform:translateY(20px) scale(.95)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.modal-close{
  position:absolute;top:14px;right:14px;
  width:34px;height:34px;border-radius:50%;
  border:1px solid rgba(147,197,253,.18);
  background:rgba(255,255,255,.04);
  color:var(--muted);font-size:20px;line-height:1;
  cursor:pointer;font-family:inherit;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s,border-color .15s;
}
.modal-close:hover{
  background:rgba(255,255,255,.08);
  color:var(--text);
  border-color:rgba(147,197,253,.35);
}
.modal-badge{
  width:72px;height:72px;border-radius:50%;
  margin:4px auto 18px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#34d399,#059669);
  color:#fff;
  box-shadow:
    0 0 0 6px rgba(16,185,129,.12),
    0 0 0 12px rgba(16,185,129,.06),
    0 14px 36px -10px rgba(16,185,129,.6);
  animation:badgePop .45s cubic-bezier(.2,.9,.3,1.4) .05s both;
}
@keyframes badgePop{
  from{opacity:0;transform:scale(.4)}
  to{opacity:1;transform:scale(1)}
}
.modal-badge-err{
  background:linear-gradient(135deg,#f87171,#dc2626);
  font-size:34px;font-weight:900;
  box-shadow:
    0 0 0 6px rgba(239,68,68,.14),
    0 0 0 12px rgba(239,68,68,.06),
    0 14px 36px -10px rgba(220,38,38,.6);
}
.modal-card h2{
  margin:0 0 10px;
  font-size:24px;
  font-weight:800;
  letter-spacing:-.015em;
  color:var(--text);
}
.modal-sub{
  margin:0 0 22px;
  color:var(--muted);
  font-size:14.5px;
  line-height:1.55;
  max-width:340px;
  margin-left:auto;margin-right:auto;
}
.modal-sub strong{color:#cfe0ff;font-weight:700}
.btn-cta-happ{
  width:100%;min-width:0;
  padding:18px 28px;
  font-size:16px;
  background:linear-gradient(180deg,#10b981,#047857);
  box-shadow:
    0 1px 0 rgba(255,255,255,.22) inset,
    0 -2px 12px rgba(0,0,0,.18) inset,
    0 16px 36px -12px rgba(16,185,129,.65),
    0 0 0 1px rgba(110,231,183,.3);
}
.btn-cta-happ .btn-glow{display:none}
.modal-advanced{
  margin-top:18px;
  text-align:left;
}
.modal-advanced summary{
  cursor:pointer;
  font-size:13.5px;
  color:#9bb8e8;
  padding:8px 0;
  user-select:none;
  list-style:none;
  text-align:center;
  transition:color .15s;
}
.modal-advanced summary:hover{color:#cfe0ff}
.modal-advanced summary::-webkit-details-marker{display:none}
.modal-advanced summary::after{content:" ▾";opacity:.6;font-size:10px;margin-left:2px}
.modal-advanced[open] summary::after{content:" ▴"}
.modal-advanced .demo-link-row{
  margin-top:12px;
  display:flex;gap:8px;
}
.modal-advanced .demo-link-row input{
  flex:1;min-width:0;
  padding:11px 13px;
  border:1px solid rgba(147,197,253,.2);
  border-radius:10px;
  font-family:ui-monospace,Menlo,Consolas,monospace;
  font-size:12.5px;
  color:#cfe0ff;
  background:rgba(7,13,28,.6);
  outline:none;
}
.modal-advanced .demo-link-row input:focus{
  border-color:rgba(96,165,250,.55);
  background:rgba(7,13,28,.85);
}
.modal-advanced .demo-link-row button{
  padding:11px 18px;
  border:none;border-radius:10px;
  background:linear-gradient(180deg,#3b82f6,#1d4ed8);
  color:#fff;font-weight:600;
  cursor:pointer;
  font-family:inherit;
  font-size:13.5px;
  box-shadow:0 8px 20px -8px rgba(59,130,246,.6);
  transition:filter .15s,transform .1s;
}
.modal-advanced .demo-link-row button:hover{filter:brightness(1.1)}
.modal-advanced .demo-link-row button:active{transform:translateY(1px)}
.modal-tip{
  margin:12px 0 0;
  font-size:12.5px;
  color:var(--muted);
  text-align:center;
  opacity:.85;
}
.modal-store{
  display:block;
  margin-top:14px;
  font-size:13px;
  color:#9bb8e8;
  text-decoration:none;
  transition:color .15s;
}
.modal-store:hover{color:#cfe0ff;text-decoration:underline}

/* Store row — three download buttons (iOS / Android / Windows) */
.store-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(147,197,253,.12);
}
.store-row::before{
  content:"Нет приложения? Скачайте Happ:";
  grid-column:1/-1;
  font-size:12.5px;
  color:var(--muted);
  text-align:center;
  margin-bottom:2px;
  letter-spacing:.01em;
}
.store-btn{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:12px 8px;
  border-radius:14px;
  text-decoration:none;
  color:#cfe0ff;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(147,197,253,.18);
  font-size:12.5px;
  font-weight:600;
  letter-spacing:.01em;
  transition:transform .15s,background .15s,border-color .15s,color .15s,box-shadow .2s;
  overflow:hidden;
  isolation:isolate;
}
.store-btn::before{
  content:"";
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg, rgba(59,130,246,.18), rgba(59,130,246,0));
  opacity:0;
  transition:opacity .2s;
}
.store-btn:hover{
  color:#fff;
  background:rgba(59,130,246,.12);
  border-color:rgba(96,165,250,.55);
  transform:translateY(-2px);
  box-shadow:0 14px 28px -14px rgba(59,130,246,.6);
}
.store-btn:hover::before{opacity:1}
.store-btn:active{transform:translateY(0)}
.store-btn svg{
  color:#93c5fd;
  filter:drop-shadow(0 4px 10px rgba(96,165,250,.45));
  transition:color .15s,filter .15s;
}
.store-btn:hover svg{
  color:#fff;
  filter:drop-shadow(0 4px 14px rgba(147,197,253,.7));
}

.modal-error .btn-cta-secondary{
  width:100%;min-width:0;
  margin-top:6px;
}

@media (max-width:520px){
  .modal-card{padding:28px 22px 20px;border-radius:20px;max-width:380px}
  .modal-card h2{font-size:20px}
  .modal-badge{width:60px;height:60px;margin-bottom:14px}
  .modal-sub{margin-bottom:18px;font-size:14px}
}

.btn-glow{
  position:absolute;inset:-2px;border-radius:inherit;
  background:linear-gradient(135deg,#60a5fa,#3b82f6,#1d4ed8,#60a5fa);
  background-size:200% 200%;
  z-index:-1;
  filter:blur(18px);
  opacity:.55;
  animation:shine 4s linear infinite;
}
@keyframes shine{
  0%{background-position:0% 50%}
  100%{background-position:200% 50%}
}

/* ===== Meta list ===== */
.meta{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px 14px;
  max-width:480px;
}
.meta li{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(147,197,253,.15);
  padding:8px 14px;
  border-radius:99px;
  font-size:13.5px;
  color:var(--muted);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.meta li b{color:var(--text);font-weight:600}
.dot{
  width:6px;height:6px;border-radius:50%;
  background:linear-gradient(135deg,#60a5fa,#3b82f6);
  box-shadow:0 0 8px rgba(96,165,250,.7);
  flex-shrink:0;
}

.hint{
  color:var(--muted);
  font-size:14px;
  max-width:420px;
}

.footer-note{
  margin-top:8px;
  color:#6b7e9c;
  font-size:13px;
  line-height:1.6;
  max-width:460px;
  text-wrap:balance;
}

.notice{
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:14px;
  background:#ffffff;
  color:#0b1733;
  border-radius:16px;
  padding:18px 22px;
  max-width:520px;
  width:100%;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.08);
  text-align:left;
}
.notice p{
  margin:0;
  font-size:14.5px;
  line-height:1.5;
  font-weight:700;
  color:#0b1733;
}
.notice-ico{
  flex-shrink:0;
  width:34px;height:34px;
  border-radius:50%;
  background:#ef4444;
  color:#fff;
  font-weight:900;
  font-size:20px;
  line-height:34px;
  text-align:center;
  box-shadow:0 6px 18px rgba(239,68,68,.5);
}

/* ===== Toast ===== */
.toast{
  position:fixed;
  bottom:32px;
  left:50%;
  transform:translateX(-50%) translateY(160%);
  background:rgba(15,21,40,.95);
  border:1px solid rgba(147,197,253,.25);
  color:var(--text);
  padding:13px 24px;
  border-radius:13px;
  font-size:14px;
  font-weight:500;
  box-shadow:0 18px 40px rgba(0,0,0,.5);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  z-index:100;
  pointer-events:none;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:var(--ok);color:#bbf7d0}
.toast.err{border-color:var(--err);color:#fecaca}

@media (max-width:480px){
  .btn-cta{min-width:0;width:100%;padding:18px 28px;font-size:16px}
  .meta li{font-size:12.5px;padding:7px 12px}
  body{padding:32px 18px}
}
