/* Prolyn UI system (shared across public/ pages) */
:root{
  --bg:#0f1419;
  --card:#1a2332;
  --text:#e6edf3;
  --muted:#8b949e;
  --accent:#58a6ff;
  --accent-soft:rgba(88,166,255,.16);
  --green:#3fb950;
  --danger:#f85149;
  --border:#30363d;
  --radius:12px;
  --radius-sm:10px;
  --shadow:0 18px 60px rgba(0,0,0,.38);

  --font-sans:'DM Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --font-head:'Space Grotesk',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;

  --container:980px;
  --gutter:16px;
  --space-1:8px;
  --space-2:12px;
  --space-3:16px;
  --space-4:24px;
  --space-5:32px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{color-scheme:dark}
body{
  font-family:var(--font-sans);
  background:
    linear-gradient(120deg,rgba(5,11,22,.32),rgba(5,11,20,.6)),
    url("https://assets.zyrosite.com/AzGMgM5BW0C747Zp/33e0cb36-7c2b-4cc5-921f-6bafb59a0c42-WxgAk6wJknBDqGVq.png");
  background-attachment:fixed;
  background-size:cover;
  font-size:17px;
  color:var(--text);
  line-height:1.5;
  min-height:100vh;
  padding:var(--gutter);
  padding-bottom:64px;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.bubble-field{
  position:fixed;
  inset:0;
  overflow:hidden;
  pointer-events:none;
  z-index:-1;
}
.bubble{
  position:absolute;
  width:12px;
  height:12px;
  border-radius:50%;
  border:1.5px solid rgba(255,255,255,.7);
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.98),transparent 60%);
  opacity:.9;
  filter:drop-shadow(0 0 6px rgba(255,255,255,.45));
  animation-timing-function:linear;
  animation-iteration-count:infinite;
}

.bubble-path-1{animation-name:bubblePath1;}
.bubble-path-2{animation-name:bubblePath2;}
.bubble-path-3{animation-name:bubblePath3;}
.bubble-path-4{animation-name:bubblePath4;}
.bubble-path-5{animation-name:bubblePath5;}
.bubble-path-6{animation-name:bubblePath6;}
.bubble-path-7{animation-name:bubblePath7;}
.bubble-path-8{animation-name:bubblePath8;}

@keyframes bubblePath1{
  0%{transform:translate3d(5vw,110vh,0);}
  100%{transform:translate3d(20vw,-10vh,0);}
}
@keyframes bubblePath2{
  0%{transform:translate3d(85vw,110vh,0);}
  100%{transform:translate3d(70vw,-10vh,0);}
}
@keyframes bubblePath3{
  0%{transform:translate3d(-10vw,20vh,0);}
  100%{transform:translate3d(110vw,0vh,0);}
}
@keyframes bubblePath4{
  0%{transform:translate3d(110vw,80vh,0);}
  100%{transform:translate3d(-10vw,40vh,0);}
}
@keyframes bubblePath5{
  0%{transform:translate3d(15vw,-10vh,0);}
  100%{transform:translate3d(30vw,110vh,0);}
}
@keyframes bubblePath6{
  0%{transform:translate3d(75vw,-10vh,0);}
  100%{transform:translate3d(55vw,110vh,0);}
}
@keyframes bubblePath7{
  0%{transform:translate3d(-10vw,-10vh,0);}
  100%{transform:translate3d(30vw,110vh,0);}
}
@keyframes bubblePath8{
  0%{transform:translate3d(110vw,-10vh,0);}
  100%{transform:translate3d(60vw,110vh,0);}
}

@keyframes fadeSlideUp{
  from{opacity:0;transform:translate3d(0,12px,0);}
  to{opacity:1;transform:translate3d(0,0,0);}
}
@keyframes fadeInScale{
  from{opacity:0;transform:scale(.96);}
  to{opacity:1;transform:scale(1);}
}

.container{max-width:var(--container);margin:0 auto}
.container.narrow{max-width:720px}
.container.tight{max-width:560px}

/* Links */
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

.app-header{
  text-align:center;
  padding:24px 0 16px;
  border-bottom:1px solid var(--border);
  animation:fadeSlideUp .7s ease-out both;
}
.app-title{
  font-family:var(--font-head);
  font-size:clamp(1.35rem,3.2vw,1.75rem);
  font-weight:800;
  letter-spacing:-.01em;
  text-shadow:0 4px 18px rgba(0,0,0,.85);
}
.app-subtitle{
  color:var(--muted);
  font-size:.95rem;
  margin-top:4px;
  text-shadow:0 3px 12px rgba(0,0,0,.9);
}
.app-nav{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:12px;
}
.app-nav a{font-size:.95rem}
.crumbs{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  font-size:.95rem;
  color:var(--muted);
  align-items:center;
}

.hero-visual{
  position:relative;
  overflow:hidden;
}
.hero-visual::before{
  content:"";
  position:absolute;
  inset:-2px;
  background-image:
    linear-gradient(115deg,rgba(5,11,22,0.55),rgba(5,11,20,0.9)),
    url("https://assets.zyrosite.com/AzGMgM5BW0C747Zp/33e0cb36-7c2b-4cc5-921f-6bafb59a0c42-WxgAk6wJknBDqGVq.png");
  background-size:cover;
  background-position:center;
  opacity:.88;
  filter:saturate(1.05);
  transform:scale(1.02);
}
.hero-visual > *{
  position:relative;
  z-index:1;
}

.card{
  background:var(--card);
  border:1px solid rgba(48,54,61,.9);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  animation:fadeInScale .55s ease-out both;
}
.card.pad{padding:20px}
.card + .card{margin-top:16px}

.section{margin-top:24px}
.section-title{
  font-family:var(--font-head);
  font-size:.98rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--text);
  margin-bottom:12px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.02);
  color:var(--text);
  border-radius:10px;
  padding:11px 14px;
  font-weight:800;
  cursor:pointer;
  font-family:var(--font-head);
  font-size:.95rem;
  text-decoration:none;
  transition:transform .14s ease, filter .14s ease, border-color .14s ease, background-color .14s ease;
  will-change:transform;
  animation:fadeSlideUp .45s ease-out both;
}
.btn:hover{border-color:rgba(88,166,255,.65);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--green);border-color:transparent}
.btn.primary:hover{filter:brightness(1.08)}
.btn.full{width:100%}
.btn:disabled,.btn[aria-disabled="true"]{opacity:.55;cursor:not-allowed;transform:none}

label{display:block;font-size:.9rem;color:var(--muted);margin-bottom:4px}
input[type="text"],input[type="tel"],input[type="number"],select,textarea{
  width:100%;
  padding:11px 12px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:10px;
  color:var(--text);
  font-size:1rem;
  outline:none;
}
textarea{min-height:90px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(88,166,255,.7);box-shadow:0 0 0 4px rgba(88,166,255,.14)}

table{width:100%;border-collapse:collapse}
th,td{border-bottom:1px solid var(--border);padding:10px 0;font-size:.95rem;vertical-align:top}
th{color:var(--muted);font-weight:800;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;text-align:left}

.table-wrap{overflow:auto;-webkit-overflow-scrolling:touch}
.table-min-720{min-width:720px}

.muted{color:var(--muted);font-size:.9rem}
.small{color:var(--muted);font-size:.94rem}
.warn{color:var(--danger)}
.ok{color:var(--green)}
.stack{display:flex;flex-direction:column;gap:12px}
.row{display:flex;gap:12px;align-items:center}
.btns{display:flex;gap:10px;flex-wrap:wrap}
.small-note{
  color:var(--text);
  font-size:.9rem;
  margin-top:0.55rem;
  padding:0.6rem 0.75rem;
  border-radius:12px;
  background:rgba(4,8,14,.9);
  display:block;
}

/* Motion */
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important;animation:none!important}
}

/* Mobile tweaks */
@media (max-width:520px){
  :root{--gutter:14px}
  .btn{width:100%}
  .hero-visual::before{
    opacity:.7;
    background-position:center;
  }
}

