/* Fragments Studio — site styles */

:root {
  --bg:        #0a0a0b;
  --bg-soft:   #111114;
  --panel:     #131318;
  --panel-2:   #16161c;
  --border:    #26262e;
  --border-lit:#34343f;
  --text:      #ececf1;
  --text-dim:  #a6a6b3;
  --text-faint:#6f6f7c;
  --accent:    #b5a8ff;
  --accent-dim:#8f82e6;
  --accent-glow: rgba(150, 130, 255, 0.22);
  --maxw:      720px;
  --radius:    16px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.wrap {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 84px 28px 60px;
  flex: 1 0 auto;
}

a { color: var(--accent); text-decoration: none; transition: color .15s ease; }
a:hover { color: var(--accent-dim); }

strong { color: var(--text); font-weight: 600; }

/* ---------- Hero ---------- */
.hero { position: relative; text-align: center; padding-top: 8px; }
.hero-glow {
  position: absolute;
  top: -90px; left: 50%;
  width: 460px; height: 460px;
  transform: translateX(-50%);
  background: radial-gradient(circle, var(--accent-glow) 0%, rgba(150,130,255,0) 68%);
  pointer-events: none;
  z-index: 0;
}
.brand-logo {
  position: relative;
  z-index: 1;
  width: 104px; height: 104px;
  display: block;
  margin: 0 auto 22px;
  filter: drop-shadow(0 0 26px rgba(150,130,255,0.30));
}
h1 {
  position: relative; z-index: 1;
  font-size: clamp(2rem, 6.5vw, 3.1rem);
  line-height: 1.12;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-weight: 700;
  margin: 0 0 18px;
  color: #f4f3f8;
}
.tagline {
  position: relative; z-index: 1;
  font-size: 1.08rem;
  color: var(--accent);
  font-weight: 500;
  letter-spacing: 0.02em;
  margin: 0 0 30px;
}
.lead {
  position: relative; z-index: 1;
  color: var(--text);
  font-size: 1.16rem;
  line-height: 1.6;
  max-width: 30em;
  margin: 0 auto 16px;
}
.sub {
  position: relative; z-index: 1;
  color: var(--text-dim);
  font-size: 1.02rem;
  max-width: 32em;
  margin: 0 auto 30px;
}

/* Platform pills */
.platforms {
  position: relative; z-index: 1;
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 10px;
  margin: 0 0 4px;
}
.pill {
  border: 1px solid var(--border-lit);
  background: var(--panel);
  color: var(--text-dim);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 7px 16px;
  border-radius: 999px;
}

/* Star divider */
.star-div {
  display: flex; align-items: center;
  gap: 18px;
  margin: 52px 0;
  color: var(--accent);
}
.star-div::before, .star-div::after {
  content: ""; flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-lit), transparent);
}
.star-div span { font-size: 1.1rem; opacity: 0.85; }

/* ---------- Info panels ---------- */
.panels {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.panel {
  background: linear-gradient(180deg, var(--panel-2), var(--panel));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px 26px;
}
.panel h2 {
  display: flex; align-items: center; gap: 9px;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--text-faint);
  margin: 0 0 13px;
  font-weight: 700;
}
.panel h2::before { content: "✦"; color: var(--accent); font-size: 0.8rem; }
.panel p { color: var(--text-dim); font-size: 0.95rem; line-height: 1.62; margin: 0 0 12px; }
.panel p:last-child { margin-bottom: 0; }

/* Contact strip */
.contact {
  text-align: center;
  margin: 36px 0 0;
  font-size: 1rem;
  color: var(--text-dim);
}
.contact a { font-weight: 500; }

/* ---------- Footer ---------- */
footer {
  flex-shrink: 0;
  border-top: 1px solid var(--border);
  padding: 26px 28px;
  margin-top: 28px;
}
.footer-inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 10px 20px;
  font-size: 0.9rem;
  color: var(--text-faint);
}
.footer-inner a { color: var(--text-dim); }
.footer-inner a:hover { color: var(--text); }
.footer-inner .sep { color: var(--border-lit); }
.footer-inner .copy { margin-left: auto; }

/* ---------- Legal / content pages ---------- */
.doc { text-align: left; }
.doc .back { display: inline-block; margin-bottom: 30px; font-size: 0.92rem; }
.doc h1 {
  font-size: clamp(2rem, 5vw, 2.5rem);
  margin-bottom: 6px; text-align: left;
  background: none; color: var(--text);
  -webkit-text-fill-color: var(--text);
}
.doc .updated { color: var(--text-faint); font-size: 0.9rem; margin: 0 0 36px; }
.doc h2 { font-size: 1.2rem; margin: 38px 0 12px; color: var(--text); letter-spacing: -0.01em; }
.doc h3 { font-size: 1.02rem; margin: 24px 0 8px; color: var(--text); }
.doc p, .doc li { color: var(--text-dim); font-size: 0.99rem; }
.doc ul { padding-left: 22px; margin: 0 0 20px; }
.doc li { margin-bottom: 8px; }
.doc a { text-decoration: underline; text-underline-offset: 3px; }

/* ---------- OAuth callback ---------- */
.cb { text-align: center; }
.cb .brand-logo { width: 80px; height: 80px; }
.cb .status { font-size: 1.5rem; font-weight: 600; margin: 12px 0 8px; }
.cb p { color: var(--text-dim); }
.cb code {
  display: block;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  margin: 18px 0;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.9rem; color: var(--text); word-break: break-all;
}

@media (max-width: 600px) {
  .wrap { padding: 60px 20px 48px; }
  .panels { grid-template-columns: 1fr; }
  .footer-inner .copy { margin-left: 0; width: 100%; }
}
