/* Landing/Legal pages styled to match malzi.me brand */

/* ── Self-hosted Fonts (1:1 malzi.me) ── */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('./fonts/inter/inter-latin.2dcd361203.woff2') format('woff2');
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400 500;
  font-display: swap;
  src: url('./fonts/jetbrains-mono/jetbrains-mono-latin.66e5c4a8f3.woff2') format('woff2');
}

:root{
  --bg:#0a0c10;
  --surface:#111318;
  --card:#161921;
  --text:#c8cdd8;
  --text-hi:#e8ecf4;
  --muted:#9ca3af;
  --accent:#38bdf8;
  --accent-dim:rgba(56,189,248,.10);
  --border:#1e222d;
}
*{box-sizing:border-box}
html,body{
  margin:0;
  padding:0;
  background:var(--bg);
  color:var(--text);
  font:16px/1.55 "Inter",-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;
}
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body{
  background:var(--bg);
}
a{color:#dbeafe;text-decoration:none}
.back-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--muted);
  font-size:.88rem;
  text-decoration:none;
  transition:color .2s;
}
.back-link:hover{ color:var(--accent); }

/* Legal pages (1:1 malzi.me) */
.legal-page{
  max-width:640px;
  margin:0 auto;
  padding-bottom:40px;
}
.legal-page h1{
  margin-top:0;
  margin-bottom:6px;
  font-size:clamp(1.6rem,4.5vw,2.4rem);
  font-weight:700;
  color:var(--text-hi);
  line-height:1.2;
}
.legal-subtitle{
  color:var(--muted);
  font-size:1rem;
  margin-bottom:28px;
}
.legal-header{
  display:flex;
  justify-content:flex-start;
  margin:4px 0 14px;
}
.legal-section{
  margin-bottom:28px;
}
.legal-section h2{
  font-size:1rem;
  font-weight:600;
  color:var(--text-hi);
  margin:0 0 10px;
}
.legal-section p{
  font-size:1rem;
  line-height:1.65;
  color:var(--text);
  margin:0 0 10px;
}
.legal-section a{
  color:var(--accent);
  text-decoration:none;
}
.legal-section a:hover{ text-decoration:underline; }
.legal-page a:not(.back-link){
  color:var(--accent);
  text-decoration:none;
}
.legal-page a:not(.back-link):hover{ text-decoration:underline; }
.legal-block{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px;
  padding:16px;
  margin-bottom:14px;
}
.legal-block p{
  font-size:1rem;
  line-height:1.6;
  color:var(--text);
  margin-bottom:4px;
}
.legal-block p:last-child{ margin-bottom:0; }
.legal-block a{
  color:var(--accent);
  text-decoration:none;
}
.legal-block a:hover{ text-decoration:underline; }
.legal-block--highlight{
  border-color:rgba(56,189,248,.25);
  background:rgba(56,189,248,.04);
}
.legal-list{
  padding-left:20px;
  font-size:1rem;
  line-height:1.65;
  color:var(--text);
  margin-bottom:10px;
}
.legal-list li{ margin-bottom:6px; }
.legal-list code{
  font-family:"JetBrains Mono",monospace;
  font-size:.82rem;
  background:var(--surface);
  padding:1px 5px;
  border-radius:4px;
}
.legal-list--flush{ margin-bottom:0; }
.legal-table-wrap{
  overflow-x:auto;
  margin-bottom:10px;
}

.topbar{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(15,16,32,.65);
  backdrop-filter:blur(10px) saturate(160%);
  border-bottom:1px solid var(--border);
}
.topbar .inner{
  max-width:1120px;
  margin:0 auto;
  padding:14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.brand{display:flex;align-items:center;gap:12px}
.logoimg{
  width:auto;
  height:72px;
  max-width:min(92vw, 600px);
  display:block;
}

.shell{
  max-width:1120px;
  margin:0 auto;
  padding:28px 16px 40px;
}
.card{
  background:transparent;
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:none;
  padding:24px 26px;
}
.hero{
  text-align:center;
  padding:64px 20px 48px;
  border:none;
  background:none;
}
.hero-headline{
  margin:0 0 14px;
  font-size:clamp(2.2rem, 6vw, 3.4rem);
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.1;
  color:var(--accent);
  text-transform:lowercase;
}
.hero-sub{
  margin:0 auto 32px;
  max-width:44ch;
  font-size:1.05rem;
  line-height:1.6;
  color:var(--muted);
}
.hero-form{
  display:inline-flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
}
.hero-form input[type=text]{
  width:220px;
  padding:11px 14px;
  font-size:.88rem;
  border-radius:10px;
}
.hero-form .btn.primary{
  white-space:nowrap;
}
.splash{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:12px;
  background:
    radial-gradient(800px 420px at 85% -10%, rgba(108,92,231,.22), transparent 60%),
    radial-gradient(700px 420px at -10% 10%, rgba(0,209,178,.18), transparent 60%),
    var(--bg);
  backdrop-filter:none;
  z-index:200;
}
.splash.show{ display:flex; }
.spinner{
  width:36px;
  height:36px;
  border-radius:50%;
  border:3px solid rgba(255,255,255,.2);
  border-top-color: var(--accent);
  animation:spin 0.8s linear infinite;
}
.splash-text{
  color:#d6dde5;
  font-weight:600;
  text-align:center;
}
@keyframes spin{
  to{ transform:rotate(360deg); }
}
.row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}

input[type=text]{
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background:#fff;
  color:#111;
  outline:none;
}
input[type=text]::placeholder{ color:#999; }

.btn{
  appearance:none;
  border:none;
  border-radius:10px;
  padding:12px 24px;
  background:transparent;
  color:var(--accent);
  cursor:pointer;
  font-family:"JetBrains Mono",monospace;
  font-size:.82rem;
  font-weight:500;
  letter-spacing:.04em;
  border:1px solid rgba(56,189,248,.3);
  transition:all .25s ease;
}
.btn:hover{
  background:var(--accent-dim);
  border-color:var(--accent);
  box-shadow:0 0 16px rgba(56,189,248,.15);
  transform:translateY(-1px);
}
.btn:active{ transform:translateY(0); }
.btn.primary{
  background:var(--accent-dim);
  color:var(--accent);
  border:1px solid rgba(56,189,248,.3);
}
.btn.secondary{
  background:transparent;
  color:var(--muted);
  border:1px solid rgba(255,255,255,.08);
}

/* Open Source Box (1:1 malzi.me) */
.opensource-box{
  position:relative;
  z-index:1;
  max-width:680px;
  margin:48px auto 24px;
  padding:0 20px;
  text-align:center;
}
.opensource-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 22px;
  font-family:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.04em;
  color:var(--muted);
  text-decoration:none;
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;
  background:rgba(255,255,255,.03);
  transition:all .25s ease;
}
.opensource-link:hover{
  color:var(--text-hi);
  border-color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.06);
  transform:translateY(-1px);
}
.opensource-link:active{ transform:translateY(0); }
.opensource-link svg{
  width:18px;
  height:18px;
  fill:currentColor;
  flex-shrink:0;
}

/* Support Box (1:1 malzi.me) */
.support-box{
  position:relative;
  z-index:1;
  max-width:680px;
  margin:0 auto;
  padding:0 20px;
  text-align:center;
}
.support-headline{
  font-family:"JetBrains Mono",monospace;
  font-size:.82rem;
  font-weight:500;
  letter-spacing:.06em;
  color:var(--text-hi);
  margin:0 0 4px;
}
.support-text{
  font-size:.88rem;
  color:var(--muted);
  margin:0 0 14px;
}
.support-btn{
  display:inline-block;
  padding:10px 24px;
  font-family:"JetBrains Mono",monospace;
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.04em;
  color:var(--accent);
  text-decoration:none;
  border:1px solid rgba(56,189,248,.25);
  border-radius:8px;
  background:var(--accent-dim);
  transition:all .25s ease;
}
.support-btn:hover{
  border-color:var(--accent);
  box-shadow:0 0 16px rgba(56,189,248,.15);
  transform:translateY(-1px);
}
.support-btn:active{ transform:translateY(0); }

/* Footer (1:1 malzi.me) */
.site-footer{
  text-align:center;
  padding:24px 20px;
  border-top:1px solid var(--border);
  margin-top:20px;
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap;
  font-size:.78rem;
  color:var(--muted);
}
.footer-copy{ color:var(--muted); }
.footer-sep{
  color:var(--border);
  user-select:none;
}
.site-footer a{
  color:var(--muted);
  text-decoration:none;
  transition:color .2s;
}
.site-footer a:hover{ color:var(--accent); }

.legal-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  margin:10px 0 6px;
  font-size:14px;
  display:block;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.legal-table th,
.legal-table td{
  text-align:left;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.legal-table th{
  color:#cfd8e3;
  font-weight:700;
}
.legal-table td{
  color:#d6dde5;
  overflow-wrap:anywhere;
}

.info{
  margin-top:22px;
}
.info h2{margin-top:0}
.info-grid{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  margin:18px 0 10px;
}
.info-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  background:transparent;
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:none;
  padding:14px 14px;
}
.info-item h3{margin:0 0 6px}
.info-item p{margin:0;color:#d6dde5}
.info-icon{
  width:72px;
  height:72px;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  color:var(--accent);
}
.info-icon .icon{
  width:36px;
  height:36px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

@media (max-width: 600px){
  .shell{padding:16px 12px 24px}
  .topbar .inner{padding:10px 12px}
  .logoimg{height:56px;max-width:90vw}
  .back-link{padding:8px 12px;font-size:13px;border-radius:12px}
  .hero{padding:40px 16px 32px}
  .hero-form{flex-direction:column;width:100%}
  .hero-form input[type=text]{width:100%}
  .info-grid{grid-template-columns:1fr}
  .legal-page h1{font-size:22px}
  .legal-subtitle{font-size:14px}
  footer{font-size:12px;line-height:1.6}
  .legal-table{display:block;border-spacing:0}
  .legal-table thead{display:none}
  .legal-table tbody,
  .legal-table tr,
  .legal-table td{display:block;width:100%}
  .legal-table tr{
    border:1px solid rgba(255,255,255,.08);
    border-radius:12px;
    padding:8px 10px;
    margin:10px 0;
    background:rgba(255,255,255,.02);
  }
  .legal-table td{
    border:none;
    padding:6px 2px;
    display:flex;
    justify-content:space-between;
    gap:12px;
  }
  .legal-table td::before{
    content:attr(data-label);
    font-weight:700;
    color:#cfd8e3;
  }
}
