body { background: #f4f6f9; }

:root{
  --blue: #4e8ef7;
  --blue-dark: #2f6fe0;
  --soft: #e7f0ff;
  --card: #ffffff;
  --border: #e5e7eb;
  --text: #111827;
  --muted: #6b7280;
  --shadow: 0 10px 30px rgba(17,24,39,.08);
}

.partygen-wrap{max-width:980px;margin:32px auto;padding:0 16px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text)}
.partygen-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px 20px;box-shadow:var(--shadow)}
.partygen-title{text-align:center;font-size:32px;margin:0 0 14px;font-weight:800;color:var(--text)}

.partygen-form{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;align-items:center}
.partygen-row{grid-column:span 12;display:flex;flex-direction:column}
@media(min-width:720px){ .partygen-row{grid-column:span 4} }
.partygen-label{font-weight:700;color:#374151;margin-bottom:8px}
.partygen-input{padding:12px;border-radius:10px;border:1px solid var(--border);background:#fbfdff;color:var(--text)}
.partygen-input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(78,142,247,.08)}

.partygen-actions{grid-column:span 12;display:flex;gap:12px;margin-top:8px}
.partygen-btn{flex:1;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--soft);color:#08223f;font-weight:700;cursor:pointer}
.partygen-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.partygen-primary:hover{background:var(--blue-dark)}
.partygen-ghost{background:#f0f4ff;color:#19386f}
.partygen-btn:disabled{opacity:.6;cursor:not-allowed}

.partygen-meta{margin-top:10px;color:var(--muted);font-size:14px}
.partygen-list{margin-top:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.partygen-card-item{background:#f8fbff;border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:8px}
.partygen-name{font-weight:800;color:#0b1d41;font-size:16px}
.partygen-copy{align-self:flex-end;border:0;background:#e7f0ff;color:#08315a;padding:8px 10px;border-radius:10px;cursor:pointer;font-weight:700}
.partygen-copy:hover{background:#d9e8ff}

.partygen-error{margin-top:12px;color:#b91c1c;font-weight:700}

@media (max-width: 720px) {
  .partygen-actions { flex-direction: column; }
  .partygen-btn { width: 100%; padding: 14px; font-size: 16px; }
}
